82 lines
2.5 KiB
JavaScript
82 lines
2.5 KiB
JavaScript
'use strict';
|
||
/**
|
||
* 此处建议只改下订单状态,保证能及时返回给第三方支付服务器成功状态
|
||
* 限制4秒内必须执行完全部的异步回调逻辑,建议将消息发送、返佣、业绩结算等业务逻辑异步处理(如用定时任务去处理这些异步逻辑)
|
||
* 建议再判断下金额和你业务系统订单中的金额是否一致
|
||
*/
|
||
|
||
const payCrypto = require('../libs/crypto.js'); // 获取加密服务
|
||
|
||
module.exports = async (obj) => {
|
||
let user_order_success = true;
|
||
let { data = {} } = obj;
|
||
let {
|
||
order_no,
|
||
out_trade_no,
|
||
total_fee
|
||
} = data; // uni-pay-orders 表内的数据均可获取到
|
||
|
||
console.log("type:test");
|
||
|
||
// 此处写你自己的支付成功逻辑开始-----------------------------------------------------------
|
||
// 有三种方式
|
||
// 方式一:直接写数据库操作
|
||
// 方式二:使用 await uniCloud.callFunction 调用其他云函数或云对象,云对象则使用 uniCloud.importObject('云对象名称')来请求
|
||
// 方式三:使用 await uniCloud.httpclient.request 调用http接口地址
|
||
|
||
|
||
/*
|
||
// 方式二安全模式一(加密)
|
||
let encrypted = payCrypto.aes.encrypt({
|
||
data: data, // 待加密的原文
|
||
});
|
||
await uniCloud.callFunction({
|
||
name: "你的云函数名称",
|
||
data: {
|
||
encrypted, // 传输加密数据
|
||
},
|
||
});
|
||
*/
|
||
|
||
|
||
/*
|
||
// 方式二安全模式二(只传一个订单号 out_trade_no,你自己的回调里查数据库表 uni-pay-orders 判断 status是否等于1来判断是否真的支付了)
|
||
await uniCloud.callFunction({
|
||
name: "你的云函数名称",
|
||
data: {
|
||
out_trade_no, // 支付插件订单号
|
||
},
|
||
});
|
||
*/
|
||
|
||
|
||
/*
|
||
// 方式三安全模式一(加密)
|
||
let encrypted = payCrypto.aes.encrypt({
|
||
data: data, // 待加密的原文
|
||
});
|
||
await uniCloud.httpclient.request("你的服务器接口请求地址", {
|
||
method: "POST",
|
||
data: {
|
||
encrypted, // 传输加密数据
|
||
},
|
||
});
|
||
*/
|
||
|
||
|
||
/*
|
||
// 方式三安全模式二(只传一个订单号 out_trade_no,你自己的回调里执行url请求来请求 uni-pay-co 云对象的 getOrder 接口来判断订单是否真的支付了)
|
||
await uniCloud.httpclient.request("你的服务器接口请求地址", {
|
||
method: "POST",
|
||
data: {
|
||
out_trade_no, // 支付插件订单号
|
||
},
|
||
});
|
||
*/
|
||
|
||
|
||
// 此处写你自己的支付成功逻辑结束-----------------------------------------------------------
|
||
// user_order_success = true 代表你自己的逻辑处理成功 返回 false 代表你自己的处理逻辑失败。
|
||
return user_order_success;
|
||
};
|