1、 创建支付应用
1.1、根据需要选择接口类型,这里选择支付应用。
1.2、选择使用环境
1.3、签约当面付(线下支付)
2、 使用alipay-sdk
2.1、 引入服务端SDK模块
npm i alipay-sdk
2.2、 配置app信息
var AlipaySdk = require(‘alipay-sdk‘).default;
var aliService = require("../service/aliPay");
var alipaySdk = new AlipaySdk({
appId: payConfig.ali.appId,
privateKey: payConfig.ali.privateKey,
alipayPublicKey: payConfig.ali.publicKey,
});
2.3、 使用exec方法调用接口
alipaySdk.exec(method, params, options).then(result => {
// console.log(result);
})
参数说明:
例子:
let params = {bizContent: {
outTradeNo: aliService.getRandomOrder(),
subject:‘水侠后付费取水‘,//交易标题
totalAmount:money,//订单金额
buyerId:req.session.user.openid,
}};
alipaySdk.exec(payConfig.ali.orderCreate,params).then(orderResult=>{
show("订单号"+order.tradeNo);
});
注意:
若接口文档中公共参数中有biz_content参数,那业务参数全部放在biz_content中,详见具体接口。
3、 H5支付
前端JS代码
$(document).ready(function(){
// 页面载入完成后即唤起收银台
// 此处${tradeNO}为模板语言语法,要用字符串代替
tradePay("${tradeNO}");
// 点击payButton按钮后唤起收银台
$("#payButton").click(function() {
tradePay("${tradeNO}");
});
// 通过jsapi关闭当前窗口,仅供参考,更多jsapi请访问
$("#closeButton").click(function() {
AlipayJSBridge.call(‘closeWebview‘);
});
});
// 由于js的载入是异步的,所以可以通过该方法,当AlipayJSBridgeReady事件发生后,再执行callback方法
function ready(callback) {
if (window.AlipayJSBridge) {
callback && callback();
} else {
document.addEventListener(‘AlipayJSBridgeReady‘, callback, false);
}
}
function tradePay(tradeNO) {
ready(function(){
// 通过传入交易号唤起快捷调用方式
AlipayJSBridge.call("tradePay", {
tradeNO: tradeNO
}, function (data) {
if ("9000" == data.resultCode) {
alert("支付成功");
}
});
});
}
响应说明:
4、 附录
node.js配置服务端sdk教程:https://www.npmjs.com/package/alipay-sdk
当面付接入教程:https://docs.open.alipay.com/194
名词解释:
应用网关:用于接收支付宝异步通知,例如口碑开店中,需要配置此网关来接收 开发者门店被动通知。
授权回调地址:第三方授权或用户信息授权后回调地址。授权链接中配置的red...
原文:https://www.cnblogs.com/YannYao/p/9717486.html