| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 | 
							- 'use strict';
 
- /**
 
-  *
 
-  *
 
-  * @author Mai
 
-  * @date
 
-  * @version
 
-  */
 
- const crypto = require('crypto-js');
 
- const fs = require('fs');
 
- const path = require('path');
 
- const encryptSpr = '|----|';
 
- const baseKey = crypto.enc.Utf8.parse('Sc3850?Calc888Zh'); // 十六位十六进制数作为密钥
 
- const baseIv = crypto.enc.Utf8.parse('Zh888!Sc3850Calc'); // 十六位十六进制数作为密钥偏移量
 
- const baseUtils = {
 
-     aesDecrypt: function(str, key, iv) {
 
-         const encryptedHexStr = crypto.enc.Hex.parse(str);
 
-         const src = crypto.enc.Base64.stringify(encryptedHexStr);
 
-         const decrypt = crypto.AES.decrypt(src, key, {
 
-             iv,
 
-             mode: crypto.mode.CBC,
 
-             padding: crypto.pad.Pkcs7,
 
-         });
 
-         const decryptedStr = decrypt.toString(crypto.enc.Utf8);
 
-         return decryptedStr.toString();
 
-     },
 
-     aesEncrypt: function(str, key, iv) {
 
-         const src = crypto.enc.Utf8.parse(str);
 
-         const encrypted = crypto.AES.encrypt(src, key, {
 
-             iv,
 
-             mode: crypto.mode.CBC,
 
-             padding: crypto.pad.Pkcs7,
 
-         });
 
-         return encrypted.ciphertext.toString().toUpperCase();
 
-     },
 
-     md5: function(str) {
 
-         return crypto.MD5(str).toString();
 
-     },
 
-     decryptBuffer: function(buffer) {
 
-         try {
 
-             const result = [];
 
-             const arr = buffer.split(encryptSpr);
 
-             const header = JSON.parse(this.aesDecrypt(arr[0], baseKey, baseIv));
 
-             header.key = crypto.enc.Hex.parse(header.key);
 
-             header.iv = crypto.enc.Hex.parse(header.iv);
 
-             arr.shift();
 
-             const check = this.md5(arr.join(encryptSpr));
 
-             if (check !== header.check) throw '文件被篡改';
 
-             for (const a of arr) {
 
-                 result.push(JSON.parse(this.aesDecrypt(a, header.key, header.iv)));
 
-             }
 
-             return header.data === 'array' ? result : result[0];
 
-         } catch(err) {
 
-             throw err;
 
-         }
 
-     },
 
-     getRamdonHeader: function () {
 
-         return {
 
-             key: crypto.lib.WordArray.random(16),
 
-             iv: crypto.lib.WordArray.random(16),
 
-         };
 
-     },
 
-     encryptBuffer: function(data) {
 
-         const datas = data instanceof Array ? data : [data];
 
-         const header = this.getRamdonHeader();
 
-         const arr = [];
 
-         for (const d of datas) {
 
-             arr.push(this.aesEncrypt(JSON.stringify(d), header.key, header.iv ));
 
-         }
 
-         header.key = header.key.toString();
 
-         header.iv = header.iv.toString();
 
-         header.check = this.md5(arr.join(encryptSpr));
 
-         header.data = data instanceof Array ? 'array' : 'object';
 
-         return this.aesEncrypt(JSON.stringify(header), baseKey, baseIv) + encryptSpr + arr.join(encryptSpr);
 
-     },
 
- };
 
- class baseFile {
 
-     doDecrypt(str) {
 
-     }
 
-     async decrypt(file) {
 
-         const str = await fs.readFileSync(file, 'utf-8');
 
-         return this.doDecrypt(str);
 
-     }
 
-     async recursiveMkdirSync(pathName) {
 
-         if (!fs.existsSync(pathName)) {
 
-             const upperPath = path.dirname(pathName);
 
-             if (!fs.existsSync(upperPath)) {
 
-                 await this.recursiveMkdirSync(upperPath);
 
-             }
 
-             await fs.mkdirSync(pathName);
 
-         }
 
-     }
 
-     doEncrypt(data) {
 
-     }
 
-     async encrypt(data, file) {
 
-         const buffer = this.doEncrypt(data);
 
-         // 检查文件夹是否存在,不存在则直接创建文件夹
 
-         const pathName = path.dirname(file);
 
-         if (!fs.existsSync(pathName)) await this.recursiveMkdirSync(pathName);
 
-         await fs.writeFileSync(file, buffer);
 
-     }
 
- }
 
- class cpd extends baseFile {
 
-     doEncrypt(data) {
 
-         return baseUtils.encryptBuffer(data);
 
-     }
 
-     doDecrypt(str) {
 
-         return baseUtils.decryptBuffer(str);
 
-     }
 
- }
 
- module.exports = {
 
-     cpd
 
- };
 
 
  |