From a3477b9f242933fff372f1836bff954562a94a08 Mon Sep 17 00:00:00 2001 From: VK <370725567@qq.com> Date: Mon, 29 May 2023 17:15:52 +0800 Subject: [PATCH] Update uni-pay.md --- docs/uniCloud/uni-pay.md | 33 ++++++--------------------------- 1 file changed, 6 insertions(+), 27 deletions(-) diff --git a/docs/uniCloud/uni-pay.md b/docs/uniCloud/uni-pay.md index abda1abde..86f0c41f0 100644 --- a/docs/uniCloud/uni-pay.md +++ b/docs/uniCloud/uni-pay.md @@ -1040,12 +1040,6 @@ module.exports = async (obj) => { ```js 'use strict'; -// 引入配置中心模块 -const configCenter = require("uni-config-center"); -// 获取uniPay配置 -const config = configCenter({ pluginId: 'uni-pay' }).requireFile('config.js'); -// 引入crypto模块 -const crypto = require("crypto"); /** * 此处建议只改下订单状态,保证能及时返回给第三方支付服务器成功状态 * 限制4秒内必须执行完全部的异步回调逻辑,建议将消息发送、返佣、业绩结算等业务逻辑异步处理(如用定时任务去处理这些异步逻辑) @@ -1053,6 +1047,7 @@ const crypto = require("crypto"); * 特别注意:因为金额是前端传的,需要再判断下金额和你业务系统订单中的金额是否一致,如果不一致,直接返回 return false; * 特别注意:因为金额是前端传的,需要再判断下金额和你业务系统订单中的金额是否一致,如果不一致,直接返回 return false; */ +const payCrypto = require('../libs/crypto.js'); // 获取加密服务 module.exports = async (obj) => { let user_order_success = true; let { data = {} } = obj; @@ -1066,8 +1061,11 @@ module.exports = async (obj) => { // 有三种方式 // 方式三:使用 await uniCloud.httpclient.request 调用http接口地址 - // 方式三安全模式一(加密) - let encrypted = encryptUseAes256Ecb(data); // 获得加密后的内容 + // 方式三安全模式一(加密)uni-pay的版本需 >= 2.1.0 + let encrypted = payCrypto.aes.encrypt({ + mode: "aes-256-ecb", + data: data, // 待加密的原文 + }); await uniCloud.httpclient.request("你的服务器接口请求地址", { method: "POST", data: { @@ -1090,25 +1088,6 @@ module.exports = async (obj) => { return user_order_success; }; -// aes-256-ecb加密算法 -function encryptUseAes256Ecb(data, key) { - if (!key) key = config.notifyKey; // 如果未传密钥,则用配置的密钥(密钥必须是32位的,只能是数字或字母) - let paddedData = Buffer.from(JSON.stringify(data)); - let paddedkey = key; - if (paddedkey.length > 32) { - paddedkey = paddedkey.substring(0, 32); // 截取前32位密钥 - } - paddedkey = Buffer.from(paddedkey); - const cipher = crypto.createCipheriv('aes-256-ecb', paddedkey, ''); - cipher.setAutoPadding(false); - const blockSize = 16; // AES块大小为16字节 - const paddingSize = blockSize - (paddedData.length % blockSize); - const paddingBuffer = Buffer.alloc(paddingSize, paddingSize); - paddedData = Buffer.concat([paddedData, paddingBuffer]); - let encrypted = cipher.update(paddedData, null, 'base64'); - encrypted += cipher.final('base64'); - return encrypted; -} ``` #### java解密示例代码 -- GitLab