提交 f822238b authored 作者: 钟是志's avatar 钟是志

加密很慢的问题

上级 2764de90
import baseX from "base-x";
import { apiRequest } from "../utils/request";
import { isJSON } from "@/webPublic/zyd_public/utils/utils";
import baseX from 'base-x';
import { apiRequest } from '../utils/request';
import { isJSON } from '@/webPublic/zyd_public/utils/utils';
var BASE16 = "0123456789abcdef";
var BASE16 = '0123456789abcdef';
var bs16 = baseX(BASE16);
function checkOpenBase16(){
const is_open_base14 = sessionStorage.getItem("is_open_base16")
? JSON.parse(sessionStorage.getItem("is_open_base16"))
function checkOpenBase16() {
const is_open_base14 = sessionStorage.getItem('is_open_base16')
? JSON.parse(sessionStorage.getItem('is_open_base16'))
: false;
return is_open_base14;
}
export function Base16Encode(value) {
let is_open_base14 = checkOpenBase16();
if (is_open_base14) return value ? bs16.encode(new Buffer(value)) : null;
const is_open_base14 = checkOpenBase16();
if (is_open_base14) {
if (!value) {
return null;
} else {
let newV = new Buffer(value); // 快
const r = bs16.encode(newV); // 慢
return r;
}
}
return value;
}
......@@ -28,123 +36,120 @@ const giveKey = (key, datas) => {
const encryptApiList = [
{
api: "DataColumnApi/getOptions",
key: ["filterSql"]
api: 'DataColumnApi/getOptions',
key: ['filterSql'],
},
{
api: "DataColumnApi/getLabels",
key: ["allValues"],
api: 'DataColumnApi/getLabels',
key: ['allValues'],
setNull: true,
},
{
api: "DataColumnApi/getSqlOptions",
key: ["allValues",],
query: true
api: 'DataColumnApi/getSqlOptions',
key: ['allValues'],
query: true,
},
{
api: "DataColumnApi/getSqlLabels",
key: ["allValues"],
query: true
api: 'DataColumnApi/getSqlLabels',
key: ['allValues'],
query: true,
},
{
api: "DataColumnApi/getSqlData",
key: ["allValues", "sqlKey"],
query: true
api: 'DataColumnApi/getSqlData',
key: ['allValues', 'sqlKey'],
query: true,
},
{
api: "DataRightApi/add",
key: ["filterSql"]
api: 'DataRightApi/add',
key: ['filterSql'],
},
{
api: "DataRightApi/addBatch",
key: ["filterSql"]
api: 'DataRightApi/addBatch',
key: ['filterSql'],
},
{
api: "DataObjApi/add",
key: ["sqlScript"]
api: 'DataObjApi/add',
key: ['sqlScript'],
},
{
api: "DataObjApi/getFormDataList",
key: ["custom"]
api: 'DataObjApi/getFormDataList',
key: ['custom'],
},
{
api: "DataObjApi/getFormDataPage",
key: ["sql", "custom"]
api: 'DataObjApi/getFormDataPage',
key: ['sql', 'custom'],
},
{
api: "UserApi/getPage",
key: ["addSignSql"]
api: 'UserApi/getPage',
key: ['addSignSql'],
},
{
api: "UnifiedAppFormApi/examineProcess",
key: ["taskForm"]
api: 'UnifiedAppFormApi/examineProcess',
key: ['taskForm'],
},
{
api: "UnifiedAppFormApi/saveDraft",
key: ["content"]
api: 'UnifiedAppFormApi/saveDraft',
key: ['content'],
},
{
api: "UnifiedAppFormApi/startProcess",
key: ["content"]
api: 'UnifiedAppFormApi/startProcess',
key: ['content'],
},
{
api: "UnifiedAppFormApi/startProcessByService",
key: ["content"]
api: 'UnifiedAppFormApi/startProcessByService',
key: ['content'],
},
{
api: "UnifiedAppFormApi/getHandleUser",
key: ["content"],
api: 'UnifiedAppFormApi/getHandleUser',
key: ['content'],
},
{
api: 'SqlManageEntityApi/findParamsKey',
key: ['sqlKey'],
}
},
];
const countAllValues = async (datas, item) => {
if (item.setNull) {
datas.allValues = JSON.stringify({});
} else {
if (item.query) {
if (datas?.sqlKey.length < 13) {
const response = await apiRequest("/SqlManageEntityApi/findParamsKey", { sqlKey: datas.sqlKey });
if (!response || (Array.isArray(response) && response.length === 0)) {
datas.allValues = JSON.stringify({});
} else {
const x = isJSON(data.allValues) && JSON.parse(data.allValues) || {};
const y = {};
for (let i of response) {
if (x[i]) {
y[i] = x[i];
}
datas.allValues = JSON.stringify(y);
const countAllValues = async (datas, item) => {
if (item.setNull) {
datas.allValues = JSON.stringify({});
} else {
if (item.query) {
if (datas?.sqlKey.length < 13) {
const response = await apiRequest('/SqlManageEntityApi/findParamsKey', { sqlKey: datas.sqlKey });
if (!response || (Array.isArray(response) && response.length === 0)) {
datas.allValues = JSON.stringify({});
} else {
const x = isJSON(data.allValues) && JSON.parse(data.allValues) || {};
const y = {};
for (let i of response) {
if (x[i]) {
y[i] = x[i];
}
datas.allValues = JSON.stringify(y);
}
} else {
datas.allValues = JSON.stringify({});
}
} else {
datas.allValues = JSON.stringify({});
}
}
return datas;
}
}
return datas;
};
export async function giveBase16EnCode(datas, url) { // 全局加解密函数.
if(!checkOpenBase16){
return datas;
}
// if(datas?.allValues){
// console.log(JSON.stringify(datas));
// }
if (url && typeof url === "string") {
if (!checkOpenBase16) {
return datas;
}
if (url && typeof url === 'string') {
for (let item of encryptApiList) {
if (url.indexOf(item.api) > -1) {
for (let g of item.key) {
if(g === 'allValues' && typeof datas[g] !== 'undefined'){
if (g === 'allValues' && typeof datas[g] !== 'undefined') {
datas = await countAllValues(datas, item);
datas = giveKey('allValues', datas);
}else{
} else {
datas = giveKey(g, datas);
}
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论