53 lines
2.4 KiB
Markdown
53 lines
2.4 KiB
Markdown
|
# 异步通知回调执行逻辑目录
|
|||
|
|
|||
|
**提示:异步通知写在 `uni-pay-co/notify` 目录下,在此目录新建2个js文件,分别为 `recharge.js`、`goods.js` 文件,同时复制以下代码要你新建的2个js文件里。**
|
|||
|
|
|||
|
**注意**
|
|||
|
|
|||
|
为什么要你自己创建.js文件,而不是插件默认给你创建好,这是因为后面当插件更新时,你写的代码会被插件更新的代码覆盖(一键合并功能),因此只要插件这里没有文件(而是你自己新建的文件),那么插件更新时,不会覆盖你自己新建的文件内的代码。
|
|||
|
|
|||
|
```js
|
|||
|
'use strict';
|
|||
|
/**
|
|||
|
* 此处建议只改下订单状态,保证能及时返回给第三方支付服务器成功状态
|
|||
|
* 且where条件可以增加判断服务器推送过来的金额和订单表中订单需支付金额是否一致
|
|||
|
* 将消息发送、返佣、业绩结算等业务逻辑异步处理(写入异步任务队列表)
|
|||
|
* 如开启定时器每隔5秒触发一次,处理订单
|
|||
|
* 建议再判断下金额和你业务系统订单中的金额是否一致
|
|||
|
*/
|
|||
|
module.exports = async (obj) => {
|
|||
|
let user_order_success = true;
|
|||
|
let { data = {} } = obj;
|
|||
|
let {
|
|||
|
order_no,
|
|||
|
out_trade_no,
|
|||
|
total_fee
|
|||
|
} = data; // uni-pay-orders 表内的数据均可获取到
|
|||
|
|
|||
|
// 此处写你自己的支付成功逻辑开始-----------------------------------------------------------
|
|||
|
// 有三种方式
|
|||
|
// 方式一:直接写数据库操作
|
|||
|
// 方式二:使用 await uniCloud.callFunction 调用其他云函数
|
|||
|
// 方式三:使用 await uniCloud.httpclient.request 调用http接口地址
|
|||
|
|
|||
|
// 此处写你自己的支付成功逻辑结束-----------------------------------------------------------
|
|||
|
// user_order_success = true 代表你自己的逻辑处理成功 返回 false 代表你自己的处理逻辑失败。
|
|||
|
return user_order_success;
|
|||
|
};
|
|||
|
```
|
|||
|
|
|||
|
其中
|
|||
|
|
|||
|
- `recharge.js` 内可以写余额充值相关的回调逻辑
|
|||
|
- `goods.js` 内可以写商品订单付款成功后的回调逻辑
|
|||
|
|
|||
|
最终调用哪个回调逻辑是根据你创建支付订单时,`type` 参数填的什么,`type` 如果填 `recharge` 则支付成功后就会执行 `recharge.js` 内的代码逻辑。
|
|||
|
|
|||
|
即前端调用支付时的这个 `type` 参数
|
|||
|
```js
|
|||
|
// 打开支付收银台
|
|||
|
this.$refs.uniPay.open({
|
|||
|
type: "recharge", // 支付回调类型 recharge 代表余额充值(当然你可以自己自定义)
|
|||
|
});
|
|||
|
```
|