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,
});
- appId: String 开放平台上创建应用时生成的 appId
- privateKey: String 应用私钥
- alipayPublicKey: String 支付宝公钥,用于开放平台返回值的验签
2.3、 使用exec方法调用接口
alipaySdk.exec(method, params, options).then(result => {
// console.log(result);
})
参数说明:
- 必选
- method: String 调用的 Api,比如 alipay.system.oauth.token
- 可选
- params: Object Api 的请求参数(包含部分“公共请求参数”和“请求参数”)
- bizContent: Object 可选项
- 注意: 仅当 Api 文档的“公共请求参数”列表中存在 biz_content时,才需要通过 bizContent 设置请求参数,否则应该通过 params 传递请求参数
- options: Object 可选项
- validateSign: Boolean 是否对返回值验签(依赖实例化时配置的”支付宝公钥“),默认 false
- formData: Object 文件上传类接口的请求参数,,默认 null
- log: Log 对象,存在时会调用 info、error 方法写日志,默认 null 即不写日志
- bizContent: Object 可选项
- params: Object Api 的请求参数(包含部分“公共请求参数”和“请求参数”)
- exec 返回值类型: Promise
例子:
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}");
});
