본 글은 위챗 미니 프로그램 결제 기능 개발 오류 요약 관련 정보를 주로 소개하고 있으며, 도움이 필요한 친구들이 참고할 수 있습니다.
위챗 결제 기능 개발 오류 요약 미니 프로그램
위챗 미니 프로그램 드디어 결제의 함정을 극복하고, 그 안에 꽤 큰 함정이 있다는 것을 알게 되었는데, 앞으로 함정에 빠질 학생들이 있기를 바라면서 지금 글을 올립니다. 살펴보기:
https://pay.weixin.qq.com/ wiki/doc/api/wxa/wxa_api.php?chapter=7_4&index=2
문서를 보시면 업무프로세스를 보실 수 있습니다. 첫 번째 함정은 사용자의 openid를 얻는 것입니다. 매개변수는 URL 연결에 철자를 입력해야 합니다. 그렇지 않으면 {"errcode":40013,"errmsg":"invalid appid, 힌트: [ req_id: iil1ba0504ns86 ]"} 오류가 보고됩니다.
onLoad: function () { var that = this wx.login({ success: function (res) { if (res.code) { //发起网络请求 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('获取用户登录态失败!' + res.errMsg) } } }); }
두 번째 함정은 통합 결제 주문 인터페이스입니다. 서명 함정은 MD5 암호화가 서명 도구의 암호화된 서명과 다른 경우가 많기 때문입니다
서명 암호화 툴 주소: https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=20_1
서명 및 암호화 시 변환 필수 utf-8로 암호화하고 자체 인터페이스를 사용하여 Digest.update(data.getBytes("utf-8"));
// 统一下单接口获取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 }, //统一下单 success: function (res) { var sign = res.data.strMd5 var formData = "<xml>" formData += "<appid>" + appid + "</appid>" //appid formData += "<attach>" + attach + "</attach>" //附加数据 formData += "<body>" + body + "</body>" //标题 formData += "<mch_id>" + mch_id + "</mch_id>" //商户号 formData += "<nonce_str>" + nonce_str + "</nonce_str>" //随机字符串,不长于32位。 formData += "<notify_url>" + notify_url + "</notify_url>" //异步接收微信支付结果通知的回调地址 formData += "<openid>" + openid + "</openid>" //用户Id formData += "<out_trade_no>" + out_trade_no + "</out_trade_no>" //商户订单号 formData += "<spbill_create_ip>" + spbill_create_ip + "</spbill_create_ip>" formData += "<total_fee>" + total_fee + "</total_fee>" //金额 formData += "<trade_type>" + trade_type + "</trade_type>" //公共号支付 formData += "<sign>" + sign + "</sign>"//签名 formData += "</xml>"
반환 데이터 분석 xml
//请求统一下单接口 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); } }) } }) } }); }
세 번째는 결제를 호출하려면 여기에도 몇 가지 작은 함정이 있습니다. 첫 번째는 appid로 작성할 수 없다는 것입니다. 두 번째는 prepay_id=wx2017011711060194dccf725232155886323이라는 매개변수 형식을 올바르게 작성해야 한다는 것입니다. 결제 서명 오류가 보고되며 서명 인터페이스도 확인해야 합니다. 서명이 일치하는지 확인하고 매개변수가 올바른지 확인하세요. WeChat 결제 호출 시 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 //调用微信支付 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'); } }); } }) }
를 추가해야 합니다. 읽어주셔서 감사합니다. 이 사이트를 지원해 주셔서 감사합니다.
위 내용은 WeChat 애플릿 결제 기능 개발 오류 요약에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!