Map<String, String> data = new HashMap<String, String>();
       
       /***银联全渠道系统,产品参数,除了encoding自行选择外其他不需修改***/
       //版本号
       data.put("version", DemoBase.version);  
       //字符集编码 可以使用UTF-8,GBK两种方式
       data.put("encoding", DemoBase.encoding_UTF8); 
       //签名方法
       data.put("signMethod", SDKConfig.getConfig().getSignMethod()); 
       //交易类型 03
       data.put("txnType", "03");                        
       //交易子类型  默认00
       data.put("txnSubType", "00");
       //业务类型
       data.put("bizType", "000201");  
       //渠道类型,07-PC,08-手机
       data.put("channelType", "07");                    
       
       /***商户接入参数***/
       //商户号码,请改成自己申请的商户号或者open上注册得来的777商户号测试
       data.put("merId", merId); 
       //接入类型,商户接入固定填0,不需修改
       data.put("accessType", "0");  
       //商户订单号,8-40位数字字母,不能含“-”或“_”,可以自行定制规则,重新产生,不同于原消费
       data.put("orderId", orderId); 
       //订单发送时间,格式为YYYYMMDDhhmmss,必须取当前时间,否则会报txnTime无效
       data.put("txnTime", txnTime); 
       //【撤销金额】,消费撤销时必须和原消费金额相同
       data.put("txnAmt", txnAmt);
       //交易币种(境内商户一般是156 人民币)
       data.put("currencyCode", "156");   
         
       //后台通知地址,后台通知参数详见open.unionpay.com帮助中心 下载  产品接口规范  
       //网关支付产品接口规范 消费撤销交易 商户通知,其他说明同消费交易的商户通知
       data.put("backUrl", DemoBase.backUrl);            
       
       /***要调通交易以下字段必须修改***/
       //【原始交易流水号】,原消费交易返回的的queryId,可以从消费交易后台通知接口中或者交易状态查询接口中获取
       data.put("origQryId", origQryId);               
       
       /**请求参数设置完毕,以下对请求参数进行签名并发送http post请求,接收同步应答报文**/
       //报文中certId,signature的值是在signData方法中获取并自动赋值的,只要证书配置正确即可。
       Map<String, String> reqData  = AcpService.sign(data,DemoBase.encoding_UTF8);
       
       //交易请求url从配置文件读取对应属性文件acp_sdk.properties中的 acpsdk.backTransUrl
       String url = SDKConfig.getConfig().getBackRequestUrl();
       //发送请求报文并接受同步应答(默认连接超时时间30秒,读取返回结果超时时间30秒);这里调用signData之后,
       //调用submitUrl之前不能对submitFromData中的键值对做任何修改,如果修改会导致验签不通过
       Map<String, String> rspData = AcpService.post(reqData, url,DemoBase.encoding_UTF8);
 
 
//应答码规范参考open.unionpay.com帮助中心 下载  产品接口规范  《平台接入接口规范-第5部分-附录》
                   if(!rspData.isEmpty()){
                            if(AcpService.validate(rspData, DemoBase.encoding_UTF8)){
                                     LogUtil.writeLog("验证签名成功");
                                     String respCode = rspData.get("respCode") ;
                                     if(("00").equals(respCode)){
                                               //交易已受理(不代表交易已成功),等待接收后台通知更新订单状态,也可以主动发起 查询交易确定交易状态。
                                               //TODO
                                     }else if(("03").equals(respCode)||
                                                         ("04").equals(respCode)||
                                                         ("05").equals(respCode)){
                                               //后续需发起交易状态查询交易确定交易状态
                                               //TODO
                                     }else{
                                               //其他应答码为失败请排查原因
                                               //TODO
                                     }
                            }else{
                                     LogUtil.writeErrorLog("验证签名失败");
                                     //TODO 检查验证签名失败的原因
                            }
                   }else{
                            //未返回正确的http状态
                            LogUtil.writeErrorLog("未获取到返回报文或返回http状态码非200");
                   }