讓你的微信小程序具有在線支付功能

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


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

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

wx.login({
      success: function(res) {
        if (res.code) {
          //發(fā)起網(wǎng)絡請求
          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年以來的秒數(shù)     
                   "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)
                    }
                })

那在服務器端主要要實現(xiàn)的是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 = "<xml>";
        formData += "<appid>appid</appid>"; //appid
        formData += "<attach>test</attach>";
        formData += "<body>" + body + "</body>";
        formData += "<mch_id>mch_id</mch_id>"; //商戶號
        formData += "<nonce_str>nonce_str</nonce_str>";
        formData += "<notify_url>notify_url</notify_url>";
        formData += "<openid>" + openid + "</openid>";
        formData += "<out_trade_no>" + bookingNo + "</out_trade_no>";
        formData += "<spbill_create_ip>spbill_create_ip</spbill_create_ip>";
        formData += "<total_fee>" + total_fee + "</total_fee>";
        formData += "<trade_type>JSAPI</trade_type>";
        formData += "<sign>" + paysignjsapi(appid, attach, body, mch_id, nonce_str, notify_url, openid, bookingNo, spbill_create_ip, total_fee, 'JSAPI') + "</sign>";
        formData += "</xml>";
        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);
            }
        });

下面是用到的函數(shù)

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("</" + node_name + ">");
    return _tmp[0];
}

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


最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市氛琢,隨后出現(xiàn)的幾起案子喊递,更是在濱河造成了極大的恐慌,老刑警劉巖阳似,帶你破解...
    沈念sama閱讀 206,013評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件骚勘,死亡現(xiàn)場離奇詭異,居然都是意外死亡撮奏,警方通過查閱死者的電腦和手機俏讹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,205評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來畜吊,“玉大人泽疆,你說我怎么就攤上這事×嵯祝” “怎么了殉疼?”我有些...
    開封第一講書人閱讀 152,370評論 0 342
  • 文/不壞的土叔 我叫張陵梯浪,是天一觀的道長。 經(jīng)常有香客問我株依,道長驱证,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,168評論 1 278
  • 正文 為了忘掉前任恋腕,我火速辦了婚禮抹锄,結果婚禮上,老公的妹妹穿的比我還像新娘荠藤。我一直安慰自己伙单,他們只是感情好,可當我...
    茶點故事閱讀 64,153評論 5 371
  • 文/花漫 我一把揭開白布哈肖。 她就那樣靜靜地躺著吻育,像睡著了一般。 火紅的嫁衣襯著肌膚如雪淤井。 梳的紋絲不亂的頭發(fā)上布疼,一...
    開封第一講書人閱讀 48,954評論 1 283
  • 那天,我揣著相機與錄音币狠,去河邊找鬼游两。 笑死,一個胖子當著我的面吹牛漩绵,可吹牛的內(nèi)容都是我干的贱案。 我是一名探鬼主播,決...
    沈念sama閱讀 38,271評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼止吐,長吁一口氣:“原來是場噩夢啊……” “哼宝踪!你這毒婦竟也來了?” 一聲冷哼從身側響起碍扔,我...
    開封第一講書人閱讀 36,916評論 0 259
  • 序言:老撾萬榮一對情侶失蹤瘩燥,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后蕴忆,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體颤芬,經(jīng)...
    沈念sama閱讀 43,382評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,877評論 2 323
  • 正文 我和宋清朗相戀三年套鹅,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片汰具。...
    茶點故事閱讀 37,989評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡卓鹿,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出留荔,到底是詐尸還是另有隱情吟孙,我是刑警寧澤澜倦,帶...
    沈念sama閱讀 33,624評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站杰妓,受9級特大地震影響藻治,放射性物質發(fā)生泄漏。R本人自食惡果不足惜巷挥,卻給世界環(huán)境...
    茶點故事閱讀 39,209評論 3 307
  • 文/蒙蒙 一桩卵、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧倍宾,春花似錦雏节、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,199評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至怔锌,卻和暖如春寥粹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背埃元。 一陣腳步聲響...
    開封第一講書人閱讀 31,418評論 1 260
  • 我被黑心中介騙來泰國打工涝涤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人亚情。 一個月前我還...
    沈念sama閱讀 45,401評論 2 352
  • 正文 我出身青樓妄痪,卻偏偏與公主長得像,于是被迫代替她去往敵國和親楞件。 傳聞我的和親對象是個殘疾皇子衫生,可洞房花燭夜當晚...
    茶點故事閱讀 42,700評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 給提問的開發(fā)者的建議:提問之前先查詢 文檔、通過社區(qū)右上角搜索搜索已經(jīng)存在的問題土浸。 寫一個簡明扼要的標題罪针,并且...
    極樂叔閱讀 13,384評論 0 3
  • 接受一個任務之前,把所有的功能都對照齊全,記錄下來,代碼寫完后一定要重新對照一遍,包括效果圖和所有的業(yè)務邏輯.
    不拘小節(jié)123456閱讀 487評論 0 0
  • 2017.11.23 晴 周四 晚上接孩子回家時,宇說要買計算器黄伊,我們來到了家附近的一個商店泪酱,看到...
    宇涵媽閱讀 147評論 0 0
  • directivefixed me : 不知道如何取對應的元素,所以都用了類似const dots = angul...
    laiyituan閱讀 696評論 2 2
  • 我自身雖然是財務管理專業(yè)还最,但大學時是混日子墓阀,實際上學到的理財知識很少。但我同時又是一個對互聯(lián)網(wǎng)理財非常有興趣的人拓轻。...
    魔鬼的贊歌閱讀 1,076評論 9 11