微信小程序 支付简单实例及注意事项
微信小程序 支付 微信小程序的支付和微信公众号的支付是类似的,对比起来还比公众号支付简单了一些,我们只需要调用微信的统一下单接口获取prepay_id之后我们在调用微信的支付即可。 今天我们来封装一般node的支付接口!!! 首先调用统一下单接口我们需要知道一些信息 " //appid
formData += "" + attach + "" //附加数据
formData += "" + body + ""
formData += "
这个是一个统一下单接口的代码,我们需要appid小程序公众号id,mch_id商户号id,openid小程序的唯一标实,key支付用的密码,剩下的参数都是订单的信息和价格之类的,本人require进q模块使用promise,这个因人而异,可以根据自己需要来。我们需要请求https://api.mch.weixin.qq.com/pay/unifiedorder接口 注意:这里我们传递的formdata是一个xml而不是json然后我们需要签名方法,这里我们需要封装两个方法,一个是签名方法调用统一下单接口会用到,另一个是调用小程序支付用到 统一下单接口sign: 支付sign: 注意加密的时候我们获取的是string而不是一个json,所以我们需要吧json转换成string,代码如下: 统一下单接口返回的是带有prepay_id的xml,所以我们需要一个方法进行解析,代码如下: 最后我们只需要把这些连接到一起就是可以获取所有微信支付所需参数,代码如下: string
raw: function(args) {
var keys = Object.keys(args)
keys = keys.sort()
var newArgs = {}
keys.forEach(function(key) {
newArgs[key] = args[key]
})
var string = ''
for (var k in newArgs) {
string += '&' + k + '=' + newArgs[k]
}
string = string.substr(1)
return string
},// 随机字符串产生函数
createNonceStr: function() {
return Math.random().toString(36).substr(2,15)
},// 时间戳产生函数
createTimeStamp: function() {
return parseInt(new Date().getTime() / 1000) + ''
},// 支付md5加密获取sign
paysignjs: function(appid,nonceStr,package,signType,timeStamp) {
var ret = {
appId: appid,'utf8').digest('hex')
return sign.toUpperCase()
},// 统一下单接口加密获取sign
paysignjsapi: function(appid,out_trade_no,spbill_create_ip,trade_type) {
var ret = {
appid: appid,// 下单接口
order: function(attach,notify_url) {
var bookingNo = 'davdian' + this.createNonceStr() + this.createTimeStamp()
var deferred = Q.defer()
var appid = config.appId
var nonce_str = this.createNonceStr()
var timeStamp = this.createTimeStamp()
var url = "https://api.mch.weixin.qq.com/pay/unifiedorder"
var formData = "
之后我们封装下单接口: ',data,123123)
res.json(data)
})
},
然后我们只需要在小程序里面调用这个接口,就会获取到所有的支付需要信息,再掉微信支付即可。 这里说几个小程序支付的坑:1.统一下单接口是xml(这个不只是小程序,公众号也是),返回值也是xml格式需要自己获取prepay_id, 2.签名算法要带上key,最后要转换成大些 3.微信支付的sign算法也要带上appid(这个不科学,深坑) 4.签名算法一定不要用json拼接key 感谢阅读,希望能帮助到大家,谢谢大家对本站 的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |