• 简书网微信公众号二维码
您当前的位置: 首页 > 知识百科 > 微信小程序支付流程解析

微信小程序支付流程解析

时间:2023-07-01 14:05 阅读数:119 人阅读 分类:知识百科

  小程序支付功能的实现打破了支付宝独大的局面,从功能方面来说,小程序支付也是很有用的,微信小程序支付流程是什么样子的呢?以下是微信小程序商店提供的步骤简析。

  小程序支付流程分为三步:

  1,预支付

  2,根据预支付数据+签名——>发起支付

  3,支付回调

  下面对这3个步骤进行简单描述:

  1,预支付。该小程序接口通过前端提交需支付的信息(订单号、价格等)给开发者服务器,开发者服务器在提交到微信,而后返回真正前端需要进行支付的一些信息;eg:

  开发者服务器的预支付接口:

  ()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 copyprint?

  wx.requestPayment({

  nonceStr: res.data.nonceStr,

  package: "prepay_id="+res.data.prepayId,

  signType: 'MD5',

  timeStamp: res.data.timestamp,

  paySign: sign,//五个字段参与签名(区分大小写):appId,nonceStr,package,signType,timeStamp(需要注意的是,这5个参数签名排序的顺序按照ASCII字典序排序)

  success: function(res){

  console.log("支付成功");

  },

  fail: function() {

  },

  complete: function() {

  }

  })

  3生成签名sign

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

  微信小程序MD5加密工具下载地址:code.csdn/snippets/2019875/master/download

  [javascript] view plain copyprint?

  var MD5Util = require('../../../utils/md5.js');

  [javascript] view plain copyprint?

  var sign = '';

  //顺序按照ASCII字典序排序

  var signA = "appId="+app.appId+"&nonceStr="+res.data.nonceStr+"&package=prepay_id="+res.data.prepayId+"&signType=MD5&timeStamp="+res.data.timestamp;

  var signB = signA+"&key="+app.key;

  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 copyprint?

  以上就是关于微信小程序支付流程的全部内容了,虽然只有三步,但是实际操作起来并不简单,毕竟也是需要进行小程序开发的,希望这份教程能够真正帮助到大家。

  

  个人微信小程序支付功能怎么开发和使用?

  支付宝小程序概念股的发展前景怎么样?

  支付宝小程序开发工具的优势