1. 程式人生 > >微信小程式具有線上支付功能

微信小程式具有線上支付功能

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

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

2.獲得使用者的openid 首頁我們需要在小程式的客戶端js中獲取當前使用者的openid,通過呼叫wx.login方法可以得到使用者的code,然後開發者伺服器使用登入憑證 code 獲取 openid。

wx.login({
      success: function(res) {
        if (res.code) {
          //發起網路請求
          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('獲取使用者登入態失敗!' + 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 = "<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);
            }
        });

下面是用到的函式

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步,小程式的微信支付功能就接上了,下面是測試的支付效果圖


相關推薦

讓你的程式具有線上支付功能

最近需要在微信小程式中用到線上支付功能,於是看了一下官方的文件,發現要在小程式裡實現微信支付還是很方便的,如果你以前開發過服務號下的微信支付,那麼你會發現其實小程式裡的微信支付和服務號裡的開發過程如出一轍,下面我就具體說一下小程式裡微信支付的開發流程和注意點。 1.

程式具有線上支付功能

最近需要在微信小程式中用到線上支付功能,於是看了一下官方的文件,發現要在小程式裡實現微信支付還是很方便的,如果你以前開發過服務號下的微信支付,那麼你會發現其實小程式裡的微信支付和服務號裡的開發過程如出一轍,下面我就具體說一下小程式裡微信支付的開發流程和注意點。 1.開通微信支付和微信商戶號 這個過程就和

讓你的程式具有線上支付

小編推薦:Fundebug專注於JavaScript、微信小程式、微信小遊戲,Node.js和Java實時BUG監控。真的是一個很好用的bug監控費服務,眾多大佬公司都在使用。 最近需要在微信小程式中用到線上支付功能,於是看了一下官方的文件,發現要在小程式裡實現微信支付還是很方便的

程式快速移植支付程式

 移植背景: 1. 支付寶小程式開發文件只瞭解了大致框架,跑了demo,具體Api、元件沒太多瞭解; 2. 已有微信小程式,移植支付寶小程式做預研(主要針對授權登入、支付等功能)。 3. 移植的微信小程式屬小型專案,頁面8個,元件兩個。首頁功能性較強,集成了主要的業務處理邏輯,涉及登

程式左滑刪除功能開發案例

直接進入正題,我們需要做的就是通過手指滑動列表項後,右側出現刪除; 比如說像這樣: 向左邊滑動後出現如下的效果: 開始擼程式碼~ 假設我們有N個列表項來自一個數組list,先確定基本的結構 <view class="list" wx:for="{{list}}" w

程式——評論點贊功能

實現的最終效果圖 1.點贊功能 前端頁面結構 1 <view class='talk-item-zan'> 2 <view bindtap='favorclick' data-id='{{item.id}}' data-islike="{{

程式暫停“虛擬支付”,知識付費程式可以這麼玩!

5月8日起小程式關閉虛擬支付,對於此次小程式關閉虛擬支付影響最大的,應該是知識付費/線上教育類的小程式,這類小程式現有的變現模式將受到巨大的衝擊。   一、這次整改意味著什麼?有3個需要注意   1、虛擬支付 不是所有提供支付功能的小程式都要被整改,僅僅只有涉及“虛擬支付

如何快速開通程式的流量主功能

1、先開發小程式,小程式需要有亮點,畢竟新穎(這樣別人才更好去點選檢視) 2、條件是獨立訪客(UV)不低於1000,1000人說多不多,說少也不少,因為小程式是沒有連結的,是不可以進行一個流量刷取的,獨立訪客是需要1000個實實在在的使用者,並不是訪問量。 3、開發好小程式之後,自己要

海外程式微支付程式跨境支付程式境外支付

在上一篇文章《167個國家和地區可以開通微信海外小程式》 你已經瞭解境外公司可以申請微信小程式, 可以把你的商品和服務, 在小程式中展示。 想要在小程式裡完成交易, 必須涉及到線上支付的問題, 很多人

程式實現線上報修系統

微信小程式越來越火,那麼怎麼使用微信小程式進行線上報修系統呢。是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,使用者掃一掃或搜一下即可開啟應用。 系統主要包涵:前臺報修,後臺管理、匯出資料、微信支付等常見的功能,可以檢視演示網址:微信小程式線

程式上傳圖片功能(附後端程式碼)

幾乎每個程式都需要用到圖片,在小程式中我們可以通過image元件顯示圖片。 當然小程式也是可以上傳圖片的,微信小程式文件也寫的很清楚。 上傳圖片 首先選擇圖片 通過wx.chooseImage(OBJECT)實現 官方示例程式碼 ? 1 2

程式實現快遞查詢功能(介面傳值、JSON資料請求和解析、radio-group的使用...)

執行效果: 請求資料之前需要首先在小程式平臺設定伺服器域名 第一個介面的實現:介面傳值、radio-group的使用 first.wxml <!--first.wxml--&g

程式如何實現購物車功能

不管是商城類還是餐飲類小程式,都需要通過下單完成交易,因此都需要有一個加入購物車的操作。以往購物車功能基本都是通過大量的 DOM 操作來實現,由於小程式不是基於web以此無法建立DOM。其實跟 vue.js 的用法非常像。先來弄清楚購物車的需求。單選、全選和取消,而且會隨著選

程式分頁載入功能實現

在使用類似qq,微博或者新聞類等資料量大的應用經常會遇到分頁載入功能,它不僅的應用場景廣,還能挺高使用者體驗。微信小程式中也可以分頁載入資料,這篇文章就是介紹。要實現這樣的功能,一般需要在請求資料時加入當前請求頁數,以及頁的大小(每頁顯示的數量)也有一部分介面是通過請求的開始

程式新增“星標”功能

摘要: 微信小程式新增星標功能:1、使用過小程式的使用者可以在微信的“發現”->“小程式”->“小程式歷史列表”中將小程式標為星標或取消星標。 2、已設定為星標的小程式將被固定位置,出現在小程式歷史列表的頂部。 3、當 … 正文: “ 為了

程式 c#後臺支付結果回撥

public partial class NativeNotifyPage : System.Web.UI.Page { public static string wxJsApiParam { get; set; } //前段顯示 public string r

程式實現換膚功能

在手機、電腦使用頻率如此高的當下,應用可以更換面板,以提升美觀性,並減輕螢幕對眼睛的刺激,無疑對使用者體驗有很大的幫助 這裡閒話少說,先放碼出來   github地址:我的年目標-微信小程式 演示 掃碼即可體驗,或搜尋“我的年目標” 下面為更換面板效果圖 實現功能 要實

程式weui線上入門教程-基礎元件-aiticle文章

效果圖 Wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">Article文章的排版佈局&l

程式weui線上入門教程-基礎元件-欄目首頁

效果圖 Wxml程式碼 <view class="weui-cells weui-cells_show "> <navigator url="/pages/01jichuzujian/01-article" class="weui-

程式weui線上入門教程-Weui專案的引用

專案引用 你在使用小程式從零開始開發的時候,一定會想小程式有沒有一個UI庫,類似於前端中的Bootstrap,MD,Semantic UI這樣的框架UI庫,如果有的話,一定是一個完美的事情。上帝總是寵著我們,這樣的好事情真的有,我的答案是weui.wxss。 WeUI概述 W