传输方式:采用HTTP传输(生产环境建议HTTPS)
提交方式:采用GET方式提交
字符编码:UTF-8
签名算法:MD5
签名生成的通用步骤如下
第一步: 设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA。
特别注意以下重要规则:
◆
参数名ASCII码从小到大排序(字典序);
◆ 如果参数的值为空不参与签名;
◆ 参数名区分大小写;
◆
验证调用返回或支付中心主动通知签名时,传送的sign参数不参与签名,将生成的签名与该sign值作校验。
◆ 支付中心接口可能增加字段,验证签名时必须支持增加的扩展字段
第二步: 在stringA最后拼接上key[即 StringA + "&key=" + 私钥
]
得到stringSignTemp字符串,并对stringSignTemp进行MD5运算,再将得到的字符串所有字符转换为大写,得到sign值signValue。
如请求支付系统参数如下:
Map signMap = new HashMap<>();
signMap.put("userId", "test01");
signMap.put("type", "wechat");
signMap.put("money", Double.valueOf(2));
signMap.put("remark", "");
signMap.put("outTradeNo", "P12312321123");
待签名值
:money=2.0&outTradeNo=P12312321123&type=wechat&userId=test01&key=EWEFD123RGSRETYDFNGFGFGSHDFGH签名结果
:5E0AA05DD4BB4FE5AB65608123EBA591最终请求支付系统参数
:money=2.0&outTradeNo=P12312321123&type=wechat&userId=test01&sign=5E0AA05DD4BB4FE5AB65608123EBA591
商户登录商户系统后,通过安全中心查看或修改私钥key。
接口描述
部分业务需要商户主动获取到所属用户的ID信息, 本接口可通过重定向的方式获取到用户ID信息然后在提供下一步的操作。
接口链接
URL地址:{支付网关}/api/pay/get_user_id/main
请求参数
字段名 | 变量名 | 必填 | 类型 | 示例值 | 描述 |
---|---|---|---|---|---|
商户ID | mchId | 是 | String(30) | 20001222 | 支付中心分配的商户号 |
支付产品ID | productId | 是 | String(24) | 8001 | 8004微信公众号支付,8020微信条码支付,8023微信小程序支付、8008支付宝服务窗支付、8021支付宝条码支付 |
重定向地址 | redirectUrl | 是 | String(256) | http://www.baidu.com | 重定向地址(注意做 url encode) |
签名 | sign | 是 | String(32) | C380BEC2BFD727A4B6845133519F3AD6 | 签名值,详见签名算法 |
响应结果
重定向到redirectUrl的地址,并且带入 【channelUserId】参数为用户ID. (支付宝的userID, 微信的openID, 云闪付的userNo)