yz-checkstand
v0.2.1
Published
写给 Node.js 应用的有赞二维码支付工具,关于有赞二维码支付的详细介绍请阅读[个人网站即时到账收款解决方案](https://blog.xu42.cn/2017/11/26/person-website-instant-payment-solution/)。
Downloads
5
Readme
Checkstand
写给 Node.js 应用的有赞二维码支付工具,关于有赞二维码支付的详细介绍请阅读个人网站即时到账收款解决方案。
安装
yarn add yz-checkstand
使用
首先实例化一个对象:
const Checkstand = require('yz-checkstand')
const checkstand = new Checkstand({
client_id: '应用的 client_id',
client_secret: '应用的 client_secret',
kdt_id: '应用的授权店铺 id'
})
接下来,你可以调用 createQR()
方法创建一个动态二维码:
// 第一个参数是收款金额,单位:元
// 第二个参数是收款理由,可选,如果不填会默认设置为 “收款 xx 元”
const qr = await checkstand.createQR(100, '测试有赞接口')
上面的 qr
就是 youzan.pay.qrcode.create 的响应参数。
创建二维码之后,你可以使用 isPaid()
方法主动检查用户是否已经付款:
const paid = await checkstand.isPaid(qr.qr_id)
if (paid) {
console.log('已支付')
} else {
console.log('未支付')
}
或者,你可以通过将有赞的消息推送数据传给 getPushStatus()
方法获取此次推送的二维码信息:
const KoaRouter = require('koa-router')
const bodyParser = require('koa-bodyparser')
const router = new KoaRouter()
router.post('/youzan-push', bodyParser(), async (ctx, next) => {
ctx.body = { code: 0, msg: 'success' }
next()
const orderInfo = await checkstand.getPushStatus(ctx.request.body)
if (orderInfo) {
// ...
}
})
orderInfo
是下面的对象:
{
"qr_id": "12321", // 此次交易信息关联的二维码 id
"status": "TRADE_SUCCESS", // 交易状态
"raw": { ... } // youzan.trade.get 接口的响应参数
}
getPushStatus()
方法只会处理订单状态事件中的 WAIT_BUYER_PAY
(买家已扫码,等待付款)和 TRADE_SUCCESS
(买家已付款)状态。如果你只关心 TRADE_SUCCESS
状态,可以在调用方法时给第二个参数传一个 true
:checkstand.getPushStatus(ctx.request.body, true)
。
其余情况下,orderInfo
会是 undefined
。
其它方法
除了上面介绍的常用方法,checkstand
还有这些方法:
checkstand.ensureToken()
返回一个 Promise,值是下面的一个对象:
{
"access_token": "2df2df2232df32", // 用于调用有赞接口的 token
"expires_in": 3213123322000, // token 过期时间,单位:毫秒
"create_at": 231232323123000, // token 创建时间
"scope": "trade order ..." // token 作用域
}
Checkstand 会在 token 过期时自动更新 token,所以无需担心内部细节。
checkstand.callAPI(api[, params, version])
调用有赞接口的便捷方法。例如,如果要调用 youzan.trade.get 接口,可以这样写:
checkstand.callAPI('youzan.trade.get', {
tid: '123123'
}).then(response => ...)
调用接口时,callAPI()
方法会自动带上 access_token;callAPI()
默认使用 3.0.0 版本的接口,可以用第三个参数指定接口版本。
在本地测试有赞接口
如果你有一个有赞应用,你可以在本地运行 demo 测试是否能正常支付:
- Clone 项目到本地
- 安装依赖:
yarn
或npm i
- 修改 demo/index.ts 中的有赞应用信息
- 启动应用:
yarn start
或npm start
- 启动反向代理:
yarn rp
或npm run rp
,并将有赞应用的消息推送网址设为反代服务器的地址 - 打开 http://localhost:2727
许可
MIT