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());
//交易类型 31-消费撤销
data.put("txnType", "31");
//交易子类型 默认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);