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監控費服務,眾多大佬公司都在使用。 最近需要在微信小程式中用到線上支付功能,於是看了一下官方的文件,發現要在小程式裡實現微信支付還是很方便的

Wordpress成為程式的文章管理利器

Wordpress,相信很多很多人都用過,是一款大名鼎鼎的內容管理系統(CMS),因其社群的強大,外掛的豐富,用它來建網站和部落格真的是非常方便好用。它擁有功能強大的管理後臺,使得對目錄、文章以及標籤的建立和管理,都變得輕鬆簡單。 我們在設計和開發我們的微信小程式的時候,可

程式實現線上報修系統

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

程式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

程式weui線上入門教程-WeUi基礎元件-grid九宮格

效果圖 wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">Grid</view>

程式weui線上入門教程-WeUi基礎元件-loadmore載入更多

效果圖 wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">Loadmore</view>

程式weui線上入門教程-WeUi基礎元件-footer頁尾

效果圖 wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">Footer</view>

程式weui線上入門教程-WeUi表單元件-slider滑塊

效果圖 wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">Slider</view>

程式weui線上入門教程-WeUi操作反饋-dialog對話方塊

效果圖 js程式碼 openConfirm: function () { wx.showModal({ title: '彈窗標題', content: '彈窗內容,告知當前狀態、資訊和解決方法,描述文字儘量控制

程式weui線上入門教程-WeUi操作反饋-picker選擇器

單列選擇器 時間選擇器 日期選擇器 js程式碼 data: { array: ['美國', '中國', '巴西', '日本'], index: 0, date: '2016-09-01', time: '12:01'

程式weui線上入門教程-WeUi操作反饋-msg提示頁

成功提示頁面 wxml程式碼 <view class="page"> <view class="weui-msg"> <view class="weui-msg__icon-area"> <

程式weui線上入門教程-WeUi操作反饋-actionsheet彈出式選單

效果圖 wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">ActionSheet</vie

程式weui線上入門教程-WeUi表單元件-uploader上傳

效果圖 wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">Uploader</view>

程式weui線上入門教程-WeUi表單元件-input輸入框

效果圖 wxml程式碼 <view class="page" xmlns:wx="http://www.w3.org/1999/xhtml"> <view class="page__hd"> <view class="p

程式weui線上入門教程-WeUi表單元件-list列表

效果圖 wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">List</view>

程式weui線上入門教程-WeUi表單元件-button按鈕

效果圖 wxml程式碼 <view class="page"> <view class="page__hd"> <view class="page__title">Button</view>