微信支付测试

二、微信验收公众平台验收(为微信点赞)

https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=23_1&index=2

支付验收指引

阅读对象

本文阅读对象为:商户自有系统(包括但不限于:在线购物平台、人工收银系统、自动化智能收银系统、APP应用等)负责微信支付功能验收的测试及开发人员。

验收说明

一、概述

为保证商户接入质量,提升交易安全及用户体验,微信支付的合作服务商在正式上线交易前,必须先根据本文指引完成验收。验收完成后,服务商在验收公众平台(微信号:WXPayAssist)提交验收通过申请,审核通过后,才能开通相应的支付权限(如:付款码支付)。否则,请根据审核驳回提示,重新完成验收。

注:仿真测试环境中的商户号(父子商户号)需使用真实商户号。

二、仿真测试系统

为降低商户测试门槛,微信支付团队开发了一套独立的仿真测试系统。该系统根据验收用例金额的不同返回不同的响应报文,以满足商户正常功能测试、安全/异常测试及性能测试的需求。

商户接入验收流程

图1 微信支付仿真测试系统

图1为微信支付仿真测试系统(后简称仿真系统)的简化原理图。仿真系统的API协议与正式API完全相同(API接口文档)。商户开发者只需将正式API的调用URL增加一层sandboxnew路径,即可对接到仿真系统。

例如,付款码支付URL:https://api.mch.weixin.qq.com/pay/micropay

变更为:https://api.mch.weixin.qq.com/sandboxnew/pay/micropay。

仿真系统与生产环境完全独立,包括存储层。商户在仿真系统所做的所有交易(如下单、支付、查询)均为无资金流的假数据,即:用户无需真实扣款,商户也不会有资金入账。代金券同理,沙箱环境中无需商户真实制券与发券,亦不会出现真实扣券情况。验收仿真测试系统的API验签密钥需从API获取:

获取验签秘钥API:
请求Urlhttps://api.mch.weixin.qq.com/sandboxnew/pay/getsignkey
是否需要证书
请求方式POST
请求参数:
字段名字段必填示例值类型说明
商户号mch_id1305638280String(32)微信支付分配的微信商户号
随机字符串nonce_str5K8264ILTKCH16CQ2502SI8ZNMTM67VSString(32)随机字符串,不长于32位
签名sign5K8264ILTKCH16CQ2502SI8ZNMTM67VSString(32)签名值
返回参数:
字段名字段必填示例值类型说明
返回状态码return_codeSUCCESSString(16)SUCCESS/FAIL 此字段是通信标识,非交易标识
返回信息return_msg签名失败String(128)返回信息,如非空,为错误原因 ,签名失败 ,参数格式校验错误

以下字段在return_code 为SUCCESS的时有返回。

字段名字段必填示例值类型说明
商户号mch_id1305638280String(32)微信支付分配的微信商户号
沙箱密钥sandbox_signkey013467007045764String(32)返回的沙箱密钥

商户接入仿真系统的交互流程示例:
1. 商户发起付款码支付请求,使用POST方式调用 https://api.mch.weixin.qq.com/sandboxnew/pay/micropay
2. 带sandboxnew 的https请求会被nginx路由到仿真系统。仿真系统根据支付金额(total_fee字段)返回预期报文给商户。同时,落地该笔请求数据;
3. 商户发起查单,调用 https://api.mch.weixin.qq.com/sandboxnew/pay/orderquery,带上微信订单号(transaction_id)或商户内部单号(out_trade_no);
4. 仿真系统收到查单请求后,根据单号及金额返回预期的查单结果给商户;
5. 商户下载对账单,调用 https://api.mch.weixin.qq.com/sandboxnew/pay/downloadbill,仿真系统返回固定的账单格式给商户。注:账单内容不一定与商户在仿真系统产生的交易完全相同。

三、验收流程

商户接入验收流程

图2 商户接入验收流程

如图2,商户在收到微信支付审核通过的邮件后,即可用邮件中提供的开发者信息,启动测试验收工作。验收开始后,验收负责人可按照下表步骤操作:

步骤准备项说明

1

商户通过审核,收到审核通过的邮件。

邮件中包含了商户的MCHID、APPID及密码等开发者信息。

 

2

测试硬件全部到位,且被测的APP已被成功安装在硬件。

1、APP支付:测试手机(安卓/IOS/winphone)1台,被测app及微信已安装

2、JSAPI支付:测试手机(安卓/IOS/winphone)1台,微信已安装且已关注被测公众号

3、付款码支付:被测app已被安装至收银台平板,机具或扫码枪功能正常

4、Native支付:联网PC一台,且网站已接入微信支付功能;手机1台,已安装微信

3

关注公众号“微信支付商户接入验收助手”( 微信号: WXPayAssist),在验收case栏,选择本次接入的支付类型,如付款码支付,即可看到全部验收用例。

 

 

4

修改代码或配置中所有微信支付api的链接,对接仿真系统。

例如:付款码支付现网的api

https://api.mch.weixin.qq.com/pay/micropay

变更为:

https://api.mch.weixin.qq.com/sandboxnew/pay/micropay

5

严格按照用例的顺序、金额执行用例,确保用例的检查点完全符合预期。

注意:

用例分必选和可选。必选是一定要验的,否则会直接导致验收审核不通过;可选是建议商户要做的,但不验也不会影响验收结果。

6

全部用例测试通过后,商户在公众号“我的验收”里提交验收通过申请。微信支付团队将在3个工作日内完成验收审核。

验收审核通过后,商户会收到邮件通知,相关支付权限开通,可正式上线交易;对于验收不通过的原因,可在公众号“我的验收”里查询验收详细结果,对未通过的case回归测试。

 

验收测试用例

请根据您需要开通的功能来选择相应的验收用例进行测试:

◆ 付款码支付验收用例

◆ Native支付验收用例

◆ JSAPI支付验收用例

◆ 免充值券验收用例

### 微信支付商户测试环境配置与使用方法 #### 一、获取沙箱密钥 为了能够在微信支付测试环境中顺利操作,开发者需先通过官方渠道申请并获得沙箱环境中的`mchid`(即商户)及其对应的API密钥。这一步骤至关重要,因为后续所有的接口请求都需要依赖于这些凭证来完成身份认证。 #### 二、设置开发参数 当拥有了上述提到的基础资料之后,在实际编码之前还需要做几项准备工作: - **引入SDK**:建议采用官方提供的SDK库来进行集成工作,这样可以减少很多不必要的麻烦。 - **初始化配置文件**:创建一个专门用来保存各种必要信息(比如AppID, MchId, ApiKey等)的JSON或XML格式文档;注意区分线上正式版同本地调试版本之间的差异性[^1]。 #### 三、编写代码实现交易流程 下面给出一段简单的Python脚本作为示范,展示了如何利用已有的资源发起一笔预付订单请求,并接收来自服务器端返回的数据包解析结果: ```python import requests from hashlib import sha256 import hmac import base64 def create_sign(params_dict, api_key): """生成签名""" param_string = '&'.join([f"{k}={params_dict[k]}" for k in sorted(params_dict)]) string_to_sign = f'{param_string}&key={api_key}' sign = hmac.new(string_to_sign.encode('utf8'), digestmod=sha256).hexdigest().upper() return sign if __name__ == '__main__': url = 'https://api.mch.weixin.qq.com/v3/pay/transactions/native' headers = { 'Content-Type': 'application/json', 'Accept': '*/*', 'User-Agent': '<Your User Agent>' } body_data = { "appid":"<your app id>", "mch_id":"<sandbox mch id>", "description":"test", "out_trade_no": "<unique order number>", "notify_url": "http://example.com/callback", "amount":{ "total":1, "currency":"CNY" }, "payer":{"spbill_create_ip":"127.0.0.1"} } # 假设这里已经得到了正确的sign值 authorization_header_value = f'WECHATPAY2-SHA256-RSA2048 mchid="<sandbox mch id>",nonce_str="randomString",signature="{create_sign(body_data,'<your sandbox key>')}",timestamp="1690609200"' response = requests.post(url=url,json=body_data,headers={'authorization':authorization_header_value}) print(response.text) ``` 请注意以上示例中涉及到的具体数值均应替换为真实有效的数据,特别是关于时间戳的部分要确保其准确性以避免因超时而导致验证失败的情况发生[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值