浅析微信支付:如何使用沙箱环境测试
仿真测试系统
仿真系统与生产环境完全独立,包括存储层。商户在仿真系统所做的所有交易(如下单、支付、查询)均为无资金流的假数据,即:用户无需真实扣款,商户也不会有资金入账。代金券同理,沙箱环境中无需商户真实制券与发券,亦不会出现真实扣券情况。验收仿真测试系统的API验签密钥需从API获取:
源码交互过程
注:仿真测试环境中的商户号(父子商户号)需使用真实商户号。
下面为取得sandbox_signkey的示例:
/**
*获取沙盒sandbox_signkey
*
*@authoryclimb
*@date2018/9/18
*/privatevoiddoGetSandboxSignKey()throwsException{
WXPayConfigImplconfig=WXPayConfigImpl.getInstance();
HashMapString,Stringdata=newHashMapString,String();//商户号
data.put(mch_id,config.getMchID());//获取随机字符串
data.put(nonce_str,WXPayUtil.generateNonceStr());//生成签名
Stringsign=WXPayUtil.generateSignature(data,config.getKey());
data.put(sign,sign);
//得到sandbox_signkey
WXPaywxPay=newWXPay(config);Stringresult=wxPay.requestWithoutCert(/sandboxnew/pay/getsignkey,data,10000,10000);
System.out.println(result);
}
小伙伴可以根据result来获取具体的返回数据,解析之后获取sandbox_signkey参数。
商户接入仿真系统的交互流程示例:
带sandboxnew 的https请求会被nginx路由到仿真系统。仿真系统根据支付金额(total_fee字段)返回预期报文给商户。同时,落地该笔请求数据;
仿真系统收到查单请求后,根据单号及金额返回预期的查单结果给商户;
沙箱说明:sandbox/sandboxnew
如何对接沙箱环境?
3、验收完成后,修改程序或配置中的api链接(重要!),去掉sandboxnew路径。对接现网环境。
说明地址:
结语
其实沙箱环境主要是为了方便在开发时及时获得接口返回值和进行商户支付验收使用,本文讲了如何获取sandbox_signkey参数,然后如何进行模拟对接,在实际接口URL后增加sandboxnew即可,接口会实时返回结果参数,此点于正式环境不同(正式环境支付后是异步调用,沙箱环境是实时返回)。
注意:有的接口沙箱环境的接口并不只是在链接中增加sandboxnew,整个链接都会改变,在实际操作中我们应该查看官方文档一一对照,如支付退款接口,正式线接口为:/secapi/pay/refund,而沙箱环境接口为:/sandboxnew/pay/refund,在沙箱环境中去掉了secapi这一路径,请小伙伴一定要注意。