protected void Page_Load(object sender, EventArgs e)
        {
            /**
             * 重要:联调测试时请仔细阅读注释!
             *
             * 产品:跳转网关支付产品<br>
             * 交易:消费:前台跳转,有前台通知应答和后台通知应答<br>
             * 日期: 2015-09<br>
             * 版本: 1.0.0
             * 版权: 中国银联<br>
             * 说明:以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己需要,按照技术文档编写。该代码仅供参考,不提供编码性能规范性等方面的保障<br>
             * 提示:该接口参考文档位置:open.unionpay.com帮助中心 下载  产品接口规范  《网关支付产品接口规范》,<br>
             *              《平台接入接口规范-第5部分-附录》(内包含应答码接口规范,全渠道平台银行名称-简码对照表)<br>
             *              《全渠道平台接入接口规范 第3部分 文件接口》(对账文件格式说明)<br>
             * 测试过程中的如果遇到疑问或问题您可以:1)优先在open平台中查找答案:
             *                                  调试过程中的问题或其他问题请在 https://open.unionpay.com/ajweb/help/faq/list 帮助中心 FAQ 搜索解决方案
             *                             测试过程中产生的7位应答码问题疑问请在https://open.unionpay.com/ajweb/help/respCode/respCodeList 输入应答码搜索解决方案
             *                          2) 咨询在线人工支持: open.unionpay.com注册一个用户并登陆在右上角点击“在线客服”,咨询人工QQ测试支持。
             * 交易说明:1)以后台通知或交易状态查询交易确定交易成功,前台通知不能作为判断成功的标准.
             *       2)交易状态查询交易(Form_6_5_Query)建议调用机制:前台类交易建议间隔(5分、10分、30分、60分、120分)发起交易查询,如果查询到结果成功,则不用再查询。(失败,处理中,查询不到订单均可能为中间状态)。也可以建议商户使用payTimeout(支付超时时间),过了这个时间点查询,得到的结果为最终结果。
             */

            Dictionary <string, string> param = new Dictionary <string, string>();

            //以下信息非特殊情况不需要改动
            param["version"]     = SdkConfig.Version;              //版本号
            param["encoding"]    = "UTF-8";                        //编码方式
            param["txnType"]     = "95";                           //交易类型
            param["txnSubType"]  = "00";                           //交易子类
            param["bizType"]     = "000000";                       //业务类型
            param["signMethod"]  = SdkConfig.SignMethod;           //签名方法
            param["channelType"] = "08";                           //渠道类型
            param["certType"]    = "01";                           //01:敏感信息加密公钥(只有01可用)
            param["accessType"]  = "0";                            //
            //TODO 以下信息需要填写
            param["merId"]   = Request.Form["merId"].ToString();   //商户号,请改自己的测试商户号,此处默认取demo演示页面传递的参数
            param["orderId"] = Request.Form["orderId"].ToString(); //商户订单号,8-32位数字字母,不能含“-”或“_”,此处默认取demo演示页面传递的参数,可以自行定制规则
            param["txnTime"] = Request.Form["txnTime"].ToString(); //订单发送时间,格式为YYYYMMDDhhmmss,取北京时间,此处默认取demo演示页面传递的参数,参考取法: DateTime.Now.ToString("yyyyMMddHHmmss")

            //TODO 其他特殊用法请查看 Pages/Template/special_use_purchase.htm

            AcpService.Sign(param, System.Text.Encoding.UTF8);  // 签名
            string url = SdkConfig.AppRequestUrl;

            Dictionary <String, String> rspData = AcpService.Post(param, url, System.Text.Encoding.UTF8);

            //Response.Write(DemoUtil.GetPrintResult(url, param, rspData));

            if (rspData.Count != 0)
            {
                if (AcpService.Validate(rspData, System.Text.Encoding.UTF8))
                {
                    Response.Write("商户端验证返回报文签名成功。<br>\n");
                    string respcode = rspData["respCode"]; //其他应答参数也可用此方法获取
                    if ("00" == respcode)
                    {
                        int resultCode = AcpService.UpdateEncryptCert(rspData, System.Text.Encoding.UTF8);
                        if (resultCode == 1)
                        {
                            Response.Write("加密公钥更新成功");
                        }
                        else if (resultCode == 0)
                        {
                            Response.Write("加密公钥无更新");
                        }
                        else
                        {
                            Response.Write("加密公钥更新失败");
                        }
                    }
                    else
                    {
                        //其他应答码做以失败处理
                        //TODO
                        Response.Write("失败:" + rspData["respMsg"] + "。<br>\n");
                    }
                }
                else
                {
                    Response.Write("商户端验证返回报文签名失败。<br>\n");
                }
            }
            else
            {
                Response.Write("请求失败<br>\n");
            }
        }
        protected void Page_Load(object sender, EventArgs e)
        {
            Dictionary <string, string> param = new Dictionary <string, string>();

            //以下信息非特殊情况不需要改动
            param["version"]     = SDKConfig.Version;              //版本号
            param["encoding"]    = "UTF-8";                        //编码方式
            param["txnType"]     = "95";                           //交易类型
            param["txnSubType"]  = "00";                           //交易子类
            param["bizType"]     = "000000";                       //业务类型
            param["signMethod"]  = SDKConfig.SignMethod;           //签名方法
            param["channelType"] = "08";                           //渠道类型
            param["certType"]    = "01";                           //01:敏感信息加密公钥(只有01可用)
            param["accessType"]  = "0";                            //
            //TODO 以下信息需要填写
            param["merId"]   = Request.Form["merId"].ToString();   //商户号,请改自己的测试商户号,此处默认取demo演示页面传递的参数
            param["orderId"] = Request.Form["orderId"].ToString(); //商户订单号,8-32位数字字母,不能含“-”或“_”,此处默认取demo演示页面传递的参数,可以自行定制规则
            param["txnTime"] = Request.Form["txnTime"].ToString(); //订单发送时间,格式为YYYYMMDDhhmmss,取北京时间,此处默认取demo演示页面传递的参数,参考取法: DateTime.Now.ToString("yyyyMMddHHmmss")

            //TODO 其他特殊用法请查看 pages/api_05_app/special_use_purchase.htm

            AcpService.Sign(param, System.Text.Encoding.UTF8);  // 签名
            string url = SDKConfig.AppRequestUrl;

            Dictionary <String, String> rspData = AcpService.Post(param, url, System.Text.Encoding.UTF8);

            Response.Write(DemoUtil.GetPrintResult(url, param, rspData));

            if (rspData.Count != 0)
            {
                if (AcpService.Validate(rspData, System.Text.Encoding.UTF8))
                {
                    Response.Write("商户端验证返回报文签名成功。<br>\n");
                    string respcode = rspData["respCode"]; //其他应答参数也可用此方法获取
                    if ("00" == respcode)
                    {
                        int resultCode = AcpService.UpdateEncryptCert(rspData, System.Text.Encoding.UTF8);
                        if (resultCode == 1)
                        {
                            Response.Write("加密公钥更新成功");
                        }
                        else if (resultCode == 0)
                        {
                            Response.Write("加密公钥无更新");
                        }
                        else
                        {
                            Response.Write("加密公钥更新失败");
                        }
                    }
                    else
                    {
                        //其他应答码做以失败处理
                        //TODO
                        Response.Write("失败:" + rspData["respMsg"] + "。<br>\n");
                    }
                }
                else
                {
                    Response.Write("商户端验证返回报文签名失败。<br>\n");
                }
            }
            else
            {
                Response.Write("请求失败<br>\n");
            }
        }