250 lines
7.5 KiB
JavaScript
250 lines
7.5 KiB
JavaScript
|
const express = require('express');
|
|||
|
const crypto = require('crypto');
|
|||
|
const axios = require('axios');
|
|||
|
const bodyParser = require('body-parser');
|
|||
|
const path = require('path');
|
|||
|
|
|||
|
const app = express();
|
|||
|
const port = 3000;
|
|||
|
|
|||
|
// AES CBC 加密函数,返回 Base64
|
|||
|
function aesEncrypt(plainText, key) {
|
|||
|
const keyBuffer = Buffer.from(key, 'hex'); // 将16进制的密钥转换为 Buffer
|
|||
|
const blockSize = 16; // AES 块大小
|
|||
|
const iv = crypto.randomBytes(blockSize); // 生成随机 IV
|
|||
|
const cipher = crypto.createCipheriv('aes-128-cbc', keyBuffer, iv);
|
|||
|
cipher.setAutoPadding(true);
|
|||
|
let encrypted = cipher.update(plainText);
|
|||
|
encrypted = Buffer.concat([iv, encrypted, cipher.final()]);
|
|||
|
return encrypted.toString('base64');
|
|||
|
}
|
|||
|
|
|||
|
// AES CBC 解密函数,返回解密后的明文
|
|||
|
function aesDecrypt(encryptedText, key) {
|
|||
|
const encryptedBuffer = Buffer.from(encryptedText, 'base64');
|
|||
|
const keyBuffer = Buffer.from(key, 'hex');
|
|||
|
const blockSize = 16;
|
|||
|
const iv = encryptedBuffer.slice(0, blockSize);
|
|||
|
const encryptedData = encryptedBuffer.slice(blockSize);
|
|||
|
const decipher = crypto.createDecipheriv('aes-128-cbc', keyBuffer, iv);
|
|||
|
decipher.setAutoPadding(true);
|
|||
|
let decrypted = decipher.update(encryptedData);
|
|||
|
decrypted = Buffer.concat([decrypted, decipher.final()]);
|
|||
|
return decrypted.toString();
|
|||
|
}
|
|||
|
|
|||
|
// 模拟请求参数
|
|||
|
const mockData = {
|
|||
|
"FLXG3D56": {
|
|||
|
mobile_no: "18276151590",
|
|||
|
id_card: "45212220000827423X",
|
|||
|
name: "张荣宏",
|
|||
|
time_range: "5",
|
|||
|
description: "特殊名单验证"
|
|||
|
},
|
|||
|
"FLXG54F5": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
description: "易诉人群识别"
|
|||
|
},
|
|||
|
"FLXG162A": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "张三",
|
|||
|
description: "团伙欺诈排查(通用版)"
|
|||
|
},
|
|||
|
"FLXG970F": {
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "李四",
|
|||
|
description: "风险人员核验"
|
|||
|
},
|
|||
|
"FLXG5876": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
description: "易诉人"
|
|||
|
},
|
|||
|
"FLXG9687": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "王五",
|
|||
|
description: "电诈风险预警-标准版"
|
|||
|
},
|
|||
|
"FLXGC9D1": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "赵六",
|
|||
|
description: "黑灰产等级"
|
|||
|
},
|
|||
|
"FLXGCA3D": {
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "李四",
|
|||
|
description: "个人综合涉诉"
|
|||
|
},
|
|||
|
"FLXGDEC7": {
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "张三",
|
|||
|
description: "个人不良"
|
|||
|
},
|
|||
|
"IVYZ385E": {
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "张三",
|
|||
|
description: "自然人生存状态标识"
|
|||
|
},
|
|||
|
"IVYZ5733": {
|
|||
|
name: "李四",
|
|||
|
id_card: "110101199003076534",
|
|||
|
description: "单人婚姻登记信息核验"
|
|||
|
},
|
|||
|
"IVYZ9363": {
|
|||
|
man_name: "张三",
|
|||
|
man_id_card: "110101199003076534",
|
|||
|
woman_name: "王五",
|
|||
|
woman_id_card: "110101199003076535",
|
|||
|
description: "双人婚姻状态识别"
|
|||
|
},
|
|||
|
"JRZQ0A03": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "张三",
|
|||
|
description: "借贷意向验证"
|
|||
|
},
|
|||
|
"JRZQ4AA8": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "王五",
|
|||
|
description: "偿债压力指数"
|
|||
|
},
|
|||
|
"JRZQ8203": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "赵六",
|
|||
|
description: "借贷行为验证"
|
|||
|
},
|
|||
|
"JRZQDCBE": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
id_card: "110101199003076534",
|
|||
|
bank_card: "6212261901001234567",
|
|||
|
name: "张三",
|
|||
|
description: "银行卡四要素验证"
|
|||
|
},
|
|||
|
"QYGL2ACD": {
|
|||
|
ent_name: "某企业",
|
|||
|
legal_person: "李四",
|
|||
|
ent_code: "91310000123456789X",
|
|||
|
description: "企业三要素核验"
|
|||
|
},
|
|||
|
"QYGL6F2D": {
|
|||
|
id_card: "110101199003076534",
|
|||
|
description: "人企关联"
|
|||
|
},
|
|||
|
"QYGL45BD": {
|
|||
|
ent_name: "某公司",
|
|||
|
legal_person: "王五",
|
|||
|
ent_code: "91310000123456789X",
|
|||
|
id_card: "110101199003076534",
|
|||
|
description: "企业法人四要素核验"
|
|||
|
},
|
|||
|
"QYGL8261": {
|
|||
|
ent_name: "某公司",
|
|||
|
description: "企业综合涉诉"
|
|||
|
},
|
|||
|
"QYGLB4C0": {
|
|||
|
id_card: "110101199003076534",
|
|||
|
description: "股东人企关系精准版"
|
|||
|
},
|
|||
|
"YYSY4B37": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
description: "手机在网时长"
|
|||
|
},
|
|||
|
"YYSY6F2E": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
mobile_type: "CMCC",
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "张三",
|
|||
|
description: "运营商三要素核验(详版)"
|
|||
|
},
|
|||
|
"YYSY09CD": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
mobile_type: "CUCC",
|
|||
|
id_card: "110101199003076534",
|
|||
|
name: "李四",
|
|||
|
description: "运营商三要素验证(简版)"
|
|||
|
},
|
|||
|
"YYSYBE08": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
name: "张三",
|
|||
|
description: "运营商二要素核验(手机号、姓名)"
|
|||
|
},
|
|||
|
"YYSYD50F": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
id_card: "110101199003076534",
|
|||
|
description: "运营商二要素核验(手机号、身份证)"
|
|||
|
},
|
|||
|
"YYSYF7DB": {
|
|||
|
mobile_no: "13812345678",
|
|||
|
start_date: "20220101",
|
|||
|
description: "手机二次卡"
|
|||
|
}
|
|||
|
};
|
|||
|
// 使用 EJS 模板引擎
|
|||
|
app.set('view engine', 'ejs');
|
|||
|
app.set('views', path.join(__dirname, 'views'));
|
|||
|
|
|||
|
// 解析POST请求的数据
|
|||
|
app.use(bodyParser.json());
|
|||
|
app.use(bodyParser.urlencoded({ extended: true }));
|
|||
|
|
|||
|
// 提供静态文件(比如 CSS)
|
|||
|
app.use(express.static(path.join(__dirname, 'public')));
|
|||
|
|
|||
|
// 提供前端页面
|
|||
|
app.get('/', (req, res) => {
|
|||
|
res.render('index', { interfaces: Object.keys(mockData), mockData: mockData });
|
|||
|
});
|
|||
|
|
|||
|
// 处理 API 请求
|
|||
|
app.post('/request-api', async (req, res) => {
|
|||
|
const { interfaceName, params } = req.body;
|
|||
|
|
|||
|
const url = `http://api.tianyuanapi.com/api/v1/${interfaceName}`;
|
|||
|
const accessId = 'aa16cc6e9da90461';
|
|||
|
const key = 'ff83609b2b24fc73196aac3d3dfb874f'; // AES 16进制密钥
|
|||
|
|
|||
|
const data = JSON.parse(params); // 使用用户自定义的参数
|
|||
|
const jsonStr = JSON.stringify(data);
|
|||
|
const encryptedData = aesEncrypt(jsonStr, key);
|
|||
|
|
|||
|
try {
|
|||
|
const response = await axios.post(url, { data: encryptedData }, {
|
|||
|
headers: {
|
|||
|
'Access-Id': accessId,
|
|||
|
'Content-Type': 'application/json'
|
|||
|
}
|
|||
|
});
|
|||
|
console.log(" response.data", response.data)
|
|||
|
// 如果 response.data.code 不等于 0,认为请求失败
|
|||
|
if (response.data.code !== 0) {
|
|||
|
return res.json({
|
|||
|
success: false,
|
|||
|
message: `请求失败,错误代码: ${response.data.code}`,
|
|||
|
error: response.data.message || '未知错误'
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
// 如果 code 等于 0,继续解密
|
|||
|
const encryptedResponseData = response.data.data;
|
|||
|
const decryptedData = aesDecrypt(encryptedResponseData, key);
|
|||
|
|
|||
|
res.json({
|
|||
|
success: true,
|
|||
|
encryptedResponse: response.data,
|
|||
|
decryptedResponse: JSON.parse(decryptedData)
|
|||
|
});
|
|||
|
} catch (error) {
|
|||
|
res.json({ success: false, message: '请求失败', error: error.message });
|
|||
|
}
|
|||
|
|
|||
|
});
|
|||
|
|
|||
|
app.listen(port, () => {
|
|||
|
console.log(`Server running at http://localhost:${port}`);
|
|||
|
});
|