JSAPI调起支付
更新时间:2025.02.19||
商户通过JSAPI合单下单接口获取到发起支付的必要参数prepay_id后,再通过微信浏览器内置对象方法(WeixinJSBridge)调起微信支付收银台。
接口说明
支持商户:【普通商户】
字段说明
请求参数
此API签名无后台接口交互,需要将列表中的数据签名
appId 必填 string(32)
【合单商户公众账号ID】请填写下单时传入的combine_appid
timeStamp 必填 string(32)
【时间戳】Unix时间戳,是从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数。注意:常见时间戳为秒级或毫秒级,该处必需传秒级时间戳。
nonceStr 必填 string(32)
【随机字符串】不长于32位。该值建议使用随机数算法生成。
package 必填 string(128)
【预支付交易会话标识】JSAPI合单下单接口返回的prepay_id,该值有效期为2小时,超过有效期需要重新请求JSAPI合单下单接口以获取新的prepay_id。
提交格式如:prepay_id=***。
signType 必填 string(32)
【签名类型】固定填RSA。
paySign 必填 string(512)
【签名值】使用字段appId、timeStamp、nonceStr、package计算得出的签名值 注意:取值RSA格式。详细参考JSAPI调起支付签名
注意:签名所使用的appid,为【JSAPI合单下单】时传入的combine_appid,微信支付会校验下单与调起支付所使用的appid的一致性。
请求示例
示例代码:

1function onBridgeReady() {
2 WeixinJSBridge.invoke('getBrandWCPayRequest', {
3 "appId": "wx2421b1c4370ec43b",
4 "timeStamp": "1395712654",
5 "nonceStr": "e61463f8efa94090b1f366cccfbbb444",
6 "package": "prepay_id=wx21201855730335ac86f8c43d1889123400",
7 "signType": "RSA",
8 "paySign": "oR9d8PuhnIc+YZ8cBHFCwfgpaK9gd7vaRvkYD7rthRAZ\/X+QBhcCYL21N7cHCTUxbQ+EAt6Uy+lwSN22f5YZvI45MLko8Pfso0jm46v5hqcVwrk6uddkGuT+Cdvu4WBqDzaDjnNa5UK3GfE1Wfl2gHxIIY5lLdUgWFts17D4WuolLLkiFZV+JSHMvH7eaLdT9N5GBovBwu5yYKUR7skR8Fu+LozcSqQixnlEZUfyE55feLOQTUYzLmR9pNtPbPsu6WVhbNHMS3Ss2+AehHvz+n64GDmXxbX++IOBvm2olHu3PsOUGRwhudhVf7UcGcunXt8cqNjKNqZLhLw4jq\/xDg=="
9 },
10 function(res) {
11 if (res.err_msg == "get_brand_wcpay_request:ok") {
12
13
14 }
15 });
16}
17if (typeof WeixinJSBridge == "undefined") {
18 if (document.addEventListener) {
19 document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);
20 } else if (document.attachEvent) {
21 document.attachEvent('WeixinJSBridgeReady', onBridgeReady);
22 document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);
23 }
24} else {
25 onBridgeReady();
26}返回结果值说明
用户从微信收银台返回商户页面时会触发商户调用onBridgeReady拉起支付时传入的function回调方法,商户可通过回调err_msg参数展示相应支付结果。
注:前端回调并不保证它绝对可靠,不可只依赖前端回调判断订单支付状态,订单状态需以后端查询合单订单和合单订单支付成功回调通知为准。
|
get_brand_wcpay_request:ok | 调用后端接口查单,如果订单已支付则展示支付成功页面。 |
get_brand_wcpay_request:cancel | 用户取消支付,商户可自行处理展示。 |
get_brand_wcpay_request:fail | 支付失败,展示订单支付失败结果。 |