51 lines
1.6 KiB
TypeScript
51 lines
1.6 KiB
TypeScript
import { ENCRYPT_KEY, ENCRYPT_IV } from './../../../shared/consts/consts';
|
|
import { Context } from 'egg';
|
|
const crypto = require('crypto');
|
|
const isJSON = require('koa-is-json');
|
|
|
|
function aesEncrypt(data, key, iv) {
|
|
const cipher = crypto.createCipheriv('aes-192-cbc', key, iv);
|
|
let crypted = cipher.update(data, 'utf8', 'hex');
|
|
crypted += cipher.final('hex');
|
|
return crypted;
|
|
}
|
|
|
|
function aesDecrypt(data, key, iv) {
|
|
const decipher = crypto.createDecipheriv('aes-192-cbc', key, iv);
|
|
let decrypted = decipher.update(data, 'hex', 'utf8');
|
|
decrypted += decipher.final('utf8');
|
|
return decrypted;
|
|
}
|
|
|
|
module.exports = options => {
|
|
return async function parmsDecode(ctx: Context, next) {
|
|
if (options.threshold && ctx.length < options.threshold) return;
|
|
const reqBody = ctx.request.body;
|
|
|
|
if (isJSON(reqBody)) {
|
|
const encodeStr = aesEncrypt(JSON.stringify(reqBody), ENCRYPT_KEY, ENCRYPT_IV);
|
|
console.log(`encoded str: ${encodeStr}`);
|
|
}
|
|
if (!reqBody.data) return;
|
|
|
|
const decodeStr = aesDecrypt(reqBody.data, ENCRYPT_KEY, ENCRYPT_IV);
|
|
ctx.logger.debug('decoded str:', decodeStr);
|
|
try {
|
|
ctx.request.body = JSON.parse(decodeStr);
|
|
console.log('req body', ctx.request.body);
|
|
} catch (e) {
|
|
console.error('parms parse err');
|
|
}
|
|
|
|
await next();
|
|
const resBody = ctx.body;
|
|
console.log('return value:', resBody);
|
|
if (isJSON(resBody)) {
|
|
ctx.body = { result: aesEncrypt(JSON.stringify(resBody), ENCRYPT_KEY, ENCRYPT_IV) };
|
|
} else {
|
|
ctx.body = { result: aesEncrypt(JSON.stringify({ status: 3, data: 'internal err' }), ENCRYPT_KEY, ENCRYPT_IV) };
|
|
}
|
|
};
|
|
};
|
|
|