您当前的位置: 首页 > 知识百科 > 微信小程序如何接支付宝支付?怎样实现小程序支付宝支付?

微信小程序如何接支付宝支付?怎样实现小程序支付宝支付?

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

  微信小程序开放支付功能以后,某种意义上来说,和支付宝的原理是一样的。使用小程序支付功能,甚至可以让用户从此放弃使用支付宝,毕竟它不比App,不那么占内存。那么微信小程序如何接支付宝支付呢?怎样实现小程序支付宝支付?以下是微信小程序如何接支付宝支付的具体讲解,小编提供了相关的开发流程和开发所需要的小程序码。

  1.微信小程序接支付宝支付

  2.获得用户的小程序openid

  首页我们需要在小程序中获取当前用户的小程序openid,通过小程序调用方法可以得到用户的code,然后开发者服务器使用登录凭证 code 获取 openid。

  wx.login({

  success: function(res) {

  if (res.code) {

  //发起网络请求

  wx.request({

  url: 'yourwebsit/onLogin',

  method: 'POST',

  data: {

  code: res.code

  },

  success: function(res) {

  var openid = res.data.openid;

  },

  fail: function(err) {

  console.log(err)

  }

  })

  } else {

  console.log('获取用户登录态失败!' + res.errMsg)

  }

  }

  });

  var code = req.param("code");

  request({

  url: "api.weixin.qq/sns/jscode2session?appid="+appid+"&secret="+secret+"&js_code="+code+"&grant_type=authorization_code",

  method: 'GET'

  }, function(err, response, body) {

  if (!err && response.statusCode == 200) {

  res.json(JSON.parse(body));

  }

  });

  3.获取小程序prepay_id和微信支付签名验证paySign

  这一步的过程其实就和服务号里的微信支付过程一样,分为客户端和服务器端两种模式

  在服务号里,我们是通过如下的小程序代码来调起支付功能

  function jsApiCall()

  {

  WeixinJSBridge.invoke(

  'getBrandWCPayRequest',

  {

  "appId":"", //公众号名称,由商户传入

  "timeStamp":"", //时间戳,自1970年以来的秒数

  "nonceStr":"", //随机串

  "package":"prepay_id=",

  "signType":"MD5", //微信签名方式:

  "paySign":"" //微信签名

  },

  function(res){

  WeixinJSBridge.log(res.err_msg);

  if( res.err_msg =="get_brand_wcpay_request:ok"){

  alert("支付成功!");

  }else{

  alert("支付失败!");

  }

  }

  );

  }

  wx.request({

  url: 'yourwebsit/service/getPay',

  method: 'POST',

  data: {

  bookingNo:bookingNo, /*订单号*/

  total_fee:total_fee, /*订单金额*/

  openid:openid

  },

  header: {

  'content-type': 'application/json'

  },

  success: function(res) {

  wx.requestPayment({

  'timeStamp':timeStamp,

  'nonceStr': nonceStr,

  'package': 'prepay_id='+res.data.prepay_id,

  'signType': 'MD5',

  'paySign': res.data._paySignjs,

  'success':function(res){

  console.log(res);

  },

  'fail':function(res){

  console.log('fail:'+JSON.stringify(res));

  }

  })

  },

  fail: function(err) {

  console.log(err)

  }

  })

  那在服务器端主要要实现的是prepay_id的获取和签名paySign

  var bookingNo = req.param("bookingNo");

  var total_fee = req.param("total_fee");

  var openid = req.param("openid");

  var body = "小程序费用说明";

  var url = "api.mch.weixin.qq/pay/unifiedorder";

  var formData = "";

  request({

  url: url,

  method: 'POST',

  body: formData

  }, function(err, response, body) {

  if(!err && response.statusCode == 200) {

  var prepay_id = getXMLNodeValue('prepay_id', body.toString("utf-8"));

  var tmp = prepay_id.split('[');

  var tmp1 = tmp[2].split(']');

  //签名

  var _paySignjs = paysignjs(appid, mch_id, 'prepay_id=' + tmp1[0], 'MD5',timeStamp);

  var o = {

  prepay_id: tmp1[0],

  _paySignjs: _paySignjs

  }

  res.send(o);

  }

  });

  下面是用到的小程序封装函数

  function paysignjs(appid, nonceStr, package, signType, timeStamp) {

  var ret = {

  appId: appid,

  nonceStr: nonceStr,

  package: package,

  signType: signType,

  timeStamp: timeStamp

  };

  var string = raw1(ret);

  string = string + '&key='+key;

  console.log(string);

  var crypto = require('crypto');

  return crypto.createHash('md5').update(string, 'utf8').digest('hex');

  };

  function raw1(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;

  };

  function paysignjsapi(appid, attach, body, mch_id, nonce_str, notify_url, openid, out_trade_no, spbill_create_ip, total_fee, trade_type) {

  var ret = {

  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

  };

  var string = raw(ret);

  string = string + '&key='+key;

  var crypto = require('crypto');

  return crypto.createHash('md5').update(string, 'utf8').digest('hex');

  };

  function raw(args) {

  var keys = Object.keys(args);

  keys = keys.sort()

  var newArgs = {};

  keys.forEach(function(key) {

  newArgs[key.toLowerCase()] = args[key];

  });

  var string = '';

  for(var k in newArgs) {

  string += '&' + k + '=' + newArgs[k];

  }

  string = string.substr(1);

  return string;

  };

  function getXMLNodeValue(node_name, xml) {

  var tmp = xml.split("<" + node_name + ">");

  var _tmp = tmp[1].split("");

  return _tmp[0];

  }

  看完以上资料,大家对于微信小程序如何接支付宝支付都了解了吗?实现了这个小程序功能,就能打破支付宝一家独大的局面了,大家使用起来也会更加方便。微信小程序如何接支付宝支付学习起来确实蛮有用的,希望大家在看完这份资料之后都能了解具体的开发流程,也能开发成功。如果大家对于微信小程序如何接支付宝支付还有疑惑,请在微信小程序商店搜索相关资料。

  

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

  如何打开支付宝小程序?支付宝小程序的功能

  微信小程序接入支付宝具体步骤