一赃梧、微信支付有兩種方法:
1:調(diào)用微信瀏覽器提供的內(nèi)置接口WeixinJSBridge
2:引入微信jssdk滤蝠,使用wx.chooseWXPay方法,需要先通過config接口注入權(quán)限驗(yàn)證配置授嘀。
小程序有專門的api調(diào)用 wx.requestPayment
1.1几睛、第一種一般是微信公眾號支付
在從后臺拿到簽名、時間戳這些數(shù)據(jù)后粤攒,直接調(diào)用微信瀏覽器提供的內(nèi)置接口WeixinJSBridge即可完成支付功能。
getRequestPayment(data) {
function onBridgeReady() {
WeixinJSBridge.invoke(
"getBrandWCPayRequest", {
"appId": data.appId, //公眾號ID囱持,由商戶傳入
"timeStamp": data.timeStamp, //時間戳夯接,自1970年以來的秒數(shù)
"nonceStr": data.nonceStr, //隨機(jī)串
"package": data.package,
"signType": data.signType, //微信簽名方式:
"paySign": data.paySign //微信簽名
},
function(res) {
alert(JSON.stringify(res));
// get_brand_wcpay_request
if (res.err_msg == "get_brand_wcpay_request:ok") {
// 使用以上方式判斷前端返回,微信團(tuán)隊(duì)鄭重提示:
//res.err_msg將在用戶支付成功后返回ok,但并不保證它絕對可靠纷妆。
}
}
);
}
if (typeof WeixinJSBridge == "undefined") {
if (document.addEventListener) {
document.addEventListener(
"WeixinJSBridgeReady",
onBridgeReady,
false
);
} else if (document.attachEvent) {
document.attachEvent("WeixinJSBridgeReady", onBridgeReady);
document.attachEvent("onWeixinJSBridgeReady", onBridgeReady);
}
} else {
onBridgeReady();
}
},
1.2盔几、普通的vue 商城項(xiàng)目調(diào)用微信的 SDK 來對接
1.2.1、下載微信SDK
// npm install weixin-js-sdk
import wx from "weixin-js-sdk";
1.2.2掩幢、調(diào)用后端接口逊拍,后端返回微信 SDK 所需要的數(shù)據(jù)
axios.post("onfirmOrder/payWX", data).then(res => {
//成功狀態(tài)下
if (res.data.status) {
// 存儲微信支付數(shù)據(jù)data
let {appId, nonceStr, package, paySign, signType, timeStamp, signType}= res.data.data;
console.log("即將跳轉(zhuǎn)微信支付");
//函數(shù)為分裝過得 (就是調(diào)用微信支付)
this.wexinPay(
{ appId, nonceStr, package, paySign, signType, timeStamp, },
//成功回調(diào)函數(shù)
res => {
//跳轉(zhuǎn)到下單成功頁面
this.$router.replace({ path: "/orderSuccess" });
},
err => {
//跳轉(zhuǎn)到下單成功頁面
this.$toast.fail(err.message || "支付異常");
}
);
}
else {
that.$message.error(res.data.message);
}
});
1.2.3、wexinPay方法
wexinPay(data, cb, errorCb) {
//獲取后臺傳入的數(shù)據(jù)
let appId = data.appId;
let timestamp = data.timeStamp;
let nonceStr = data.nonceStr;
let signature = data.signature;
let packages = data.package;
let paySign = data.paySign;
let signType = data.signType;
console.log('發(fā)起微信支付')
//下面要發(fā)起微信支付了
wx.config({
debug: false, // 開啟調(diào)試模式,調(diào)用的所有api的返回值會在客戶端alert出來际邻,若要查看傳入的參數(shù)芯丧,可以在pc端打開,參數(shù)信息會通過log打出世曾,僅在pc端時才會打印缨恒。
appId: appId, // 必填,公眾號的唯一標(biāo)識
timestamp: timestamp, // 必填,生成簽名的時間戳
nonceStr: nonceStr, // 必填骗露,生成簽名的隨機(jī)串
signature: signature, // 必填岭佳,簽名,見附錄1
jsApiList: ['chooseWXPay'] // 必填萧锉,需要使用的JS接口列表珊随,所有JS接口列表見附錄2
});
wx.ready(function () {
wx.chooseWXPay({
timestamp: timestamp, // 支付簽名時間戳,注意微信jssdk中的所有使用timestamp字段均為小寫柿隙。但最新版的支付后臺生成簽名使用的timeStamp字段名需大寫其中的S字符
nonceStr: nonceStr, // 支付簽名隨機(jī)串叶洞,不長于 32 位
package: packages, // 統(tǒng)一支付接口返回的prepay_id參數(shù)值,提交格式如:prepay_id=***)
signType: signType, // 簽名方式优俘,默認(rèn)為'SHA1'京办,使用新版支付需傳入'MD5'
paySign: paySign, // 支付簽名
success: function (res) {
// 支付成功后的回調(diào)函數(shù)
cb(res);
},
fail: function (res) {
//失敗回調(diào)函數(shù)
errorCb(res);
}
});
});
wx.error(function (res) {
// config信息驗(yàn)證失敗會執(zhí)行error函數(shù),如簽名過期導(dǎo)致驗(yàn)證失敗帆焕,具體錯誤信息可以打開config的debug模式查看惭婿,也可以在返回的res參數(shù)中查看,對于SPA可以在這里更新簽名叶雹。
/*alert("config信息驗(yàn)證失敗");*/
});
}
二财饥、支付寶支付和銀聯(lián)支付
支付寶支付和銀聯(lián)支付相對于微信來說,前端這塊工作更簡單 折晦,后臺會返回給前端一個form表單钥星,我們要做的就是把這個表單進(jìn)行提交即可。
銀聯(lián)支付满着、支付寶支付
axios.post("onfirmOrder/payWX", data).then((res) => {
// console.log('支付寶參數(shù)', res.data)
if (res.code == 200) {
var resData =res.data
const div = document.createElement('div')
div.id = 'alipay'
div.innerHTML = resData
document.body.appendChild(div)
document.querySelector('#alipay').children[0].submit() // 執(zhí)行后會喚起支付寶
}
}).catch((err) => {
})