十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
本文小編為大家詳細介紹“微信小程序中支付功能開發(fā)錯誤怎么解決”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當(dāng),希望這篇“微信小程序中支付功能開發(fā)錯誤怎么解決”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。
在臺江等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供做網(wǎng)站、成都網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作定制網(wǎng)站開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計,成都全網(wǎng)營銷,成都外貿(mào)網(wǎng)站建設(shè)公司,臺江網(wǎng)站建設(shè)費用合理。
業(yè)務(wù)流程在這里大家看文檔的時候可以看到。第一個坑,獲取用戶的openid,參數(shù)一定要拼在url連接上,否則會報{"errcode":40013,"errmsg":"invalid appid, hints: [ req_id: iil1ba0504ns86 ]"}錯誤
onLoad: function () { var that = this wx.login({ success: function (res) { if (res.code) { //發(fā)起網(wǎng)絡(luò)請求 wx.request({ url: 'https://api.weixin.qq.com/sns/jscode2session?appid=wxaacf22345345cfc7162fe3&secret=83ebd41c3e6f34a49b3a34578063434548ff3f71&js_code=' + res.code + '&grant_type=authorization_code', method: "POST", success: function (res) { that.setData({ openid: res.data.openid }) } }) } else { console.log('獲取用戶登錄態(tài)失??!' + res.errMsg) } } }); }
第二個坑,支付統(tǒng)一下單接口,簽名這個坑是比較多人遇到問題的這個是MD5加密經(jīng)常和簽名工具里面的加密簽名不一樣
簽名加密工具地址:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=20_1
簽名加密的時候要轉(zhuǎn)成utf-8,加密我用自己的接口進行加密的 digest.update(data.getBytes("utf-8"));
// 統(tǒng)一下單接口獲取sign(簽名) paysignjsapi: function (appid, attach, body, mch_id, nonce_str, notify_url, openid, out_trade_no, spbill_create_ip, total_fee, trade_type, key) { var self = this; //加密簽名 wx.request({ url: 'http://localhost:8080/XinXingWXApi/wxXcxApi/Md5Encrypt.do', method: 'GET', data: { appid: appid, attach: attach, body: body, mch_id: mch_id, nonce_str: nonce_str, notify_url: notify_url, openid: openid, out_trade_no: out_trade_no, spbill_create_ip: spbill_create_ip, total_fee: total_fee, trade_type: trade_type, key: key }, //統(tǒng)一下單 success: function (res) { var sign = res.data.strMd5 var formData = "" formData += " "" + appid + " " //appid formData += "" + attach + " " //附加數(shù)據(jù) formData += "" + body + "" //標(biāo)題 formData += "" + mch_id + " " //商戶號 formData += "" + nonce_str + " " //隨機字符串,不長于32位。 formData += "" + notify_url + " " //異步接收微信支付結(jié)果通知的回調(diào)地址 formData += "" + openid + " " //用戶Id formData += "" + out_trade_no + " " //商戶訂單號 formData += "" + spbill_create_ip + " " formData += "" + total_fee + " " //金額 formData += "" + trade_type + " " //公共號支付 formData += "" + sign + " "http://簽名 formData += "
返回數(shù)據(jù)解析xml
//請求統(tǒng)一下單接口 wx.request({ url: "https://api.mch.weixin.qq.com/pay/unifiedorder", method: 'POST', data: formData, success: function (data) { wx.request({ url: "http://localhost:8080/XinXingWXApi/wxXcxApi/xmlAnalyze.do?strXml=" + data.data, method: 'POST', success: function (res) { var pk = 'prepay_id=' + res.data.prepayId; var timeStamp = self.createTimeStamp(); //獲取支付簽名,并支付 self.getsignType(appid, timeStamp, nonce_str, pk, "MD5", key); } }) } }) } }); }
第三就是調(diào)用支付了,這里也有幾個小坑,第一就是appId很多寫成appid就不行了,第二個就是preoatid 的參數(shù)格式要寫對prepay_id=wx2017011711060194dccf725232155886323 第三個就是調(diào)用支付的時候報支付簽名錯誤,也需要到簽名接口查看簽名是否一致,查看參數(shù)是否是對的,調(diào)用微信支付的時候必須加上appId
getsignType: function (appid, timeStamp, nonce_str, pk, signType, key) { var that = this; wx.request({ url: "http://localhost:8080/XinXingWXApi/wxXcxApi/getSignType.hn", method: 'GET', data: { appId: appid, timeStamp: timeStamp, nonceStr: nonce_str, pk: pk, signType: signType, key: key }, success: function (res) { console.log(res.data.paySign) var paySign = res.data.paySign //調(diào)用微信支付 wx.requestPayment({ 'appId': appid, 'timeStamp': timeStamp, 'nonceStr': nonce_str, 'package': pk, 'signType': 'MD5', 'paySign': paySign, 'success': function (res) { console.log(res); console.log('success'); }, 'fail': function (res) { console.log(res); console.log('fail'); }, 'complete': function (res) { // console.log(res); console.log('complete'); } }); } }) }
讀到這里,這篇“微信小程序中支付功能開發(fā)錯誤怎么解決”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。