微信小程序进行微信支付步骤简述

最近开发微信小程序进入到支付阶段,一直以来从事App开发,所以支付流程还是熟记于心的。但是微信小程序的支付就有点奇怪了,应用的创建是在公众号里,但是文档的介绍却在公众号中无法找到直接入口,甚是不解,而且小程序的师傅到底是属于公众号支付范畴还是app支付范畴也成疑问。下面是小程序支付文档的入口(嵌套在小程序api中):

 

https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index=1

小程序支付步骤:

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

https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index=1&t=20161122

微信小程序MD5加密工具下载地址:https://code.youkuaiyun.com/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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值