真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

微信小程序在線支付功能的實現

微信小程序 在線支付功能

站在用戶的角度思考問題,與客戶深入溝通,找到河口網站設計與河口網站推廣的解決方案,憑借多年的經驗,讓設計與互聯(lián)網技術結合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網站建設、網站制作、企業(yè)官網、英文網站、手機端網站、網站推廣、主機域名、虛擬空間、企業(yè)郵箱。業(yè)務覆蓋河口地區(qū)。

最近需要在微信小程序中用到在線支付功能,于是看了一下官方的文檔,發(fā)現要在小程序里實現微信支付還是很方便的,如果你以前開發(fā)過服務號下的微信支付,那么你會發(fā)現其實小程序里的微信支付和服務號里的開發(fā)過程如出一轍,下面我就具體說一下小程序里微信支付的開發(fā)流程和注意點。

微信小程序 在線支付功能的實現

1.開通微信支付和微信商戶號

這個過程就和開通服務號的微信支付過程一樣,沒有什么可以說的。

微信小程序 在線支付功能的實現

2.獲得用戶的openid

首頁我們需要在小程序的客戶端js中獲取當前用戶的openid,通過調用wx.login方法可以得到用戶的code,然后開發(fā)者服務器使用登錄憑證 code 獲取 openid。

wx.login({
   success: function(res) {
    if (res.code) {
     //發(fā)起網絡請求
     wx.request({
      url: 'https://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('獲取用戶登錄態(tài)失敗!' + res.errMsg)
    }
   }
  });

var code = req.param("code");
    request({
      url: "https://api.weixin.qq.com/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

這一步的過程就和服務號里的微信支付過程一樣,分為客戶端和服務器端

首先來看一下客戶端js

在服務號里,我們是通過如下的代碼來調起支付功能

function jsApiCall()
    {
      WeixinJSBridge.invoke(
        'getBrandWCPayRequest',
        {
          "appId":"",   //公眾號名稱,由商戶傳入   
          "timeStamp":"",     //時間戳,自1970年以來的秒數   
          "nonceStr":"", //隨機串   
          "package":"prepay_id=<%=prepay_id%>",   
          "signType":"MD5",     //微信簽名方式:   
          "paySign":"<%=_paySignjs%>" //微信簽名
        },
        function(res){
          WeixinJSBridge.log(res.err_msg);
          if( res.err_msg =="get_brand_wcpay_request:ok"){
            alert("支付成功!");
          }else{
            alert("支付失敗!");
          }
        }
      );
    }

在小程序里,我們是通過wx.requestPayment方法來調起支付功能,當然在這之前,我們先要獲取prepay_id。

 wx.request({
          url: 'https://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 = "https://api.mch.weixin.qq.com/pay/unifiedorder";
    var formData = "";
    formData += "appid"; //appid
    formData += "test";
    formData += "" + body + "";
    formData += "mch_id"; //商戶號
    formData += "nonce_str";
    formData += "notify_url";
    formData += "" + openid + "";
    formData += "" + bookingNo + "";
    formData += "spbill_create_ip";
    formData += "" + total_fee + "";
    formData += "JSAPI";
    formData += "" + paysignjsapi(appid, attach, body, mch_id, nonce_str, notify_url, openid, bookingNo, spbill_create_ip, total_fee, 'JSAPI') + "";
    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];
}

這樣簡單3步,小程序的微信支付功能就接上了,下面是測試的支付效果圖

微信小程序 在線支付功能的實現

微信小程序 在線支付功能的實現

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


網頁題目:微信小程序在線支付功能的實現
文章URL:http://weahome.cn/article/gepdjp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部