微信小程序支付步驟


http://blog.csdn.net/wangsf789/article/details/53419781

 

最近開發微信小程序進入到支付階段,一直以來從事App開發,所以支付流程還是熟記於心的。但是微信小程序的支付就有點奇怪了,應用的創建是在公眾號里,但是文檔的介紹卻在公眾號中無法找到直接入口,甚是不解,而且小程序的師傅到底是屬於公眾號支付范疇還是app支付范疇也成疑問。下面是小程序支付文檔的入口(嵌套在小程序api中):

 

小程序支付步驟:
1,預支付
2,根據預支付數據+簽名——>發起支付
3,支付回調
下面對這3個步驟進行簡單描述:
1,預支付。該接口通過前端提交需支付的信息(訂單號、價格等)給開發者服務器,開發者服務器在提交到微信,而后返回真正前端需要進行支付的一些信息;eg:
開發者服務器的預支付接口:
https://()htm? total_fee=100&cid=6001&orderCodes=2016120119
{
    "sign":"A2****************A6",
    "timestamp":"14 ****************68",
    "package":"Sign=WXPay",
    "partnerId":"14 ****************02",
    "appid":"wx ****************ab",
    "nonceStr":"9f ****************37",
    "prepayId":"wx ****************54"
}

2,發起支付(需要注意的是發起支付是不需要上傳appid, 但是簽名paySign需要appid ,而且放在第一個)

[javascript] view plain copy
 
print?在CODE上查看代碼片派生到我的代碼片
  1. wx.requestPayment({  
  2.         nonceStr: res.data.nonceStr,  
  3.         package: "prepay_id="+res.data.prepayId,  
  4.         signType: 'MD5',  
  5.         timeStamp: res.data.timestamp,      
  6.         paySign: sign,//<strong><span style="color:#ff0000;">五個字段參與簽名(區分大小寫):appId,nonceStr,package,signType,timeStamp(需要注意的是,這5個參數簽名排序的順序按照ASCII字典序排序)</span></strong>  
  7.         success: function(res){  
  8.           console.log("支付成功");  
  9.         },  
  10.         fail: function() {  
  11.         },  
  12.         complete: function() {  
  13.         }  
  14.       })  


生成簽名sign
微信小程序 MD5加密工具下載地址:https://code.csdn.net/snippets/2019875/master/download
[javascript] view plain copy
 
print?在CODE上查看代碼片派生到我的代碼片
  1. var MD5Util = require('../../../utils/md5.js');  
[javascript] view plain copy
 
print?在CODE上查看代碼片派生到我的代碼片
  1. var sign = '';  
  2. //<strong><span style="color:#ff0000;">順序按照ASCII字典序排序</span></strong>  
  3. var signA = "appId="+app.appId+"&nonceStr="+res.data.nonceStr+"&package=prepay_id="+res.data.prepayId+"&signType=MD5&timeStamp="+res.data.timestamp;  
  4. var signB = signA+"&key="+app.key;  
  5. sign = MD5Util.MD5(signB).toUpperCase();  



生成簽名上面是我的代碼,不是很清晰, 下面列出來官方文檔的詳細描述:

假設傳送的參數如下:
appid: wxd930ea5d5a258f4f(需要注意的是appid 在wx.requestPayment({})發起支付是不上傳,但是簽名時需要)
mch_id: 10000100
device_info: 1000
body: test
nonce_str: ibuaiVcKdpRxkhJA
第一步:對參數按照key=value的格式,並按照參數名ASCII字典序排序如下:
stringA="appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_id=10000100&nonce_str=ibuaiVcKdpRxkhJA";
第二步:拼接API密鑰:
stringSignTemp="stringA&key=192006250b4c09247ec02edce69f6a2d"
sign=MD5(stringSignTemp).toUpperCase()="9A0A8659F005D6984697E2CA0A9CF3B7"
此時的sign 用於wx.requestPayment 上傳參數paySign。
最終得到最終發送的數據:
[html] view plain copy
 
print?在CODE上查看代碼片派生到我的代碼片
  1. <xml>  
  2. <appid>wxd930ea5d5a258f4f</appid>  
  3. <mch_id>10000100</mch_id>  
  4. <device_info>1000<device_info>  
  5. <body>test</body>  
  6. <nonce_str>ibuaiVcKdpRxkhJA</nonce_str>  
  7. <sign>9A0A8659F005D6984697E2CA0A9CF3B7</sign>  
  8. <xml>  

OK, 微信小程序支付完成。66666


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM