通過JSAPI下單接口獲取到發(fā)起支付的必要參數(shù)prepay_id,然后使用微信支付提供的前端JS方法調(diào)起公眾號(hào)支付。
# 接口說明
支持商戶: 【普通服務(wù)商】
# 字段說明
# 請(qǐng)求參數(shù)
此API無后臺(tái)接口交互,需要將列表中的數(shù)據(jù)簽名
- appId 必填 string(32)商戶申請(qǐng)的公眾號(hào)對(duì)應(yīng)的AppID,由微信支付生成,可在公眾號(hào)后臺(tái)
查看。若下單時(shí)傳了sub_appid,可為sub_appid的值。 - timeStamp 必填 string(32)時(shí)間戳,標(biāo)準(zhǔn)北京時(shí)間,時(shí)區(qū)為東八區(qū),自1970年1月1日 0點(diǎn)0分0秒以來的秒數(shù)。注意:部分系統(tǒng)取到的值為毫秒級(jí),需要轉(zhuǎn)換成秒(10位數(shù)字)。
- nonceStr 必填 string(32)隨機(jī)字符串,不長(zhǎng)于32位。
- package 必填 string(128)JSAPI下單接口返回的prepay_id參數(shù)值,提交格式如:prepay_id=***
- signType 必填 string(32)簽名類型,默認(rèn)為RSA,僅支持RSA。
- paySign 必填 string(256)簽名,使用字段AppID、timeStamp、nonceStr、package計(jì)算得出的簽名值
# 應(yīng)答參數(shù)
返回值 | 返回值說明 |
---|---|
get_brand_wcpay_request:ok | 支付成功 |
get_brand_wcpay_request:cancel | 支付過程中用戶取消 |
get_brand_wcpay_request:fail | 支付失敗 |
# JSAPI調(diào)起支付的參數(shù)需要按照簽名規(guī)則進(jìn)行簽名計(jì)算
# 1、構(gòu)造簽名串
1簽名串一共有四行,每一行為一個(gè)參數(shù)。行尾以\n(換行符,ASCII編碼值為0x0A)結(jié)束,包括最后一行。2如果參數(shù)本身以\n結(jié)束,也需要附加一個(gè)\n
參與簽名字段及格式:
1應(yīng)用ID2時(shí)間戳3隨機(jī)字符串4訂單詳情擴(kuò)展字符串
數(shù)據(jù)舉例:
1wx88888888888888882141456169935K8264ILTKCH16CQ2502SI8ZNMTM67VS4prepay_id=wx201410272009395522657a690389285100
# 2、計(jì)算簽名值
絕大多數(shù)編程語(yǔ)言提供的簽名函數(shù)支持對(duì)_簽名數(shù)據(jù)_ 進(jìn)行簽名。強(qiáng)烈建議商戶調(diào)用該類函數(shù),使用商戶私鑰對(duì)_待簽名串_進(jìn)行SHA256 with RSA簽名,并對(duì)簽名結(jié)果進(jìn)行_Base64編碼_得到簽名值。
# 請(qǐng)求示例
1function onBridgeReady() {2 WeixinJSBridge.invoke('getBrandWCPayRequest', {3 "appId": "wx2421b1c4370ec43b", //公眾號(hào)ID,由商戶傳入 4 "timeStamp": "1395712654", //時(shí)間戳,自1970年以來的秒數(shù) 5 "nonceStr": "e61463f8efa94090b1f366cccfbbb444", //隨機(jī)串 6 "package": "prepay_id=up_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 // 使用以上方式判斷前端返回,微信團(tuán)隊(duì)鄭重提示:13 //res.err_msg將在用戶支付成功后返回ok,但并不保證它絕對(duì)可靠。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}
# 下面我們使用命令行演示如何生成簽名
signType參數(shù)不參與簽名,但需要傳遞,默認(rèn)值為RSA,生成的簽名需要通過字段paySign傳遞。
1$ echo -n -e \2"wx8888888888888888\n1414561699\n5K8264ILTKCH16CQ2502SI8ZNMTM67VS\nprepay_id=wx201410272009395522657a690389285100\n" \3 | openssl dgst -sha256 -sign apiclient_key.pem \4 | openssl base64 -A5 uOVRnA4qG/MNnYzdQxJanN+zU+lTgIcnU9BxGw5dKjK+VdEUz2FeIoC+D5sB/LN+nGzX3hfZg6r5wT1pl2ZobmIc6p0ldN7J6yDgUzbX8Uk3sD4a4eZVPTBvqNDoUqcYMlZ9uuDdCvNv4TM3c1WzsXUrExwVkI1XO5jCNbgDJ25nkT/c1gIFvqoogl7MdSFGc4W4xZsqCItnqbypR3RuGIlR9h9vlRsy7zJR9PBI83X8alLDIfR1ukt1P7tMnmogZ0cuDY8cZsd8ZlCgLadmvej58SLsIkVxFJ8XyUgx9FmutKSYTmYtWBZ0+tNvfGmbXU7cob8H/4nLBiCwIUFluw==