8 changed files with 7482 additions and 72 deletions
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
@ -0,0 +1,34 @@ |
|||||||
|
import CryptoJS from 'crypto-js'; |
||||||
|
// 使用密钥长度128的RIJNDAEL算法解码数据,加密模式:ECB
|
||||||
|
|
||||||
|
const key = 'hbsaas1mobile2a6f8'; |
||||||
|
|
||||||
|
// 解密函数
|
||||||
|
export function decryptData(encryptedData) { |
||||||
|
// Step 1: 替换 base64 字符中的 "+" 和 "/" 为 URL 安全的字符
|
||||||
|
encryptedData = encryptedData.replace(/-/g, '+').replace(/_/g, '/'); |
||||||
|
|
||||||
|
// Step 2: 解码 base64 数据
|
||||||
|
const decodedData = CryptoJS.enc.Base64.parse(encryptedData); |
||||||
|
|
||||||
|
// Step 3: 填充 key,确保它的长度为 24 字节(128 位)
|
||||||
|
let paddedKey = key; |
||||||
|
const keyLength = paddedKey.length; |
||||||
|
if (keyLength < 24) { |
||||||
|
paddedKey = paddedKey.padEnd(24, '\0'); // 用零填充至 16 字节
|
||||||
|
} |
||||||
|
|
||||||
|
// Step 4: 使用 AES ECB 模式解密
|
||||||
|
const decryptedData = CryptoJS.AES.decrypt({ ciphertext: decodedData }, CryptoJS.enc.Utf8.parse(paddedKey), { |
||||||
|
mode: CryptoJS.mode.ECB, |
||||||
|
padding: CryptoJS.pad.Pkcs7, // 与 PHP 中的 PKCS5 padding 对应
|
||||||
|
}); |
||||||
|
|
||||||
|
// Step 5: 转换解密结果为明文字符串
|
||||||
|
return decryptedData.toString(CryptoJS.enc.Utf8); |
||||||
|
} |
||||||
|
|
||||||
|
// 示例使用:
|
||||||
|
// const encryptedData = "6QUbssj247RF6oIMf9nqT6F5LoYpAkFENy5wc572gws"; // 从 PHP 获取的加密数据
|
||||||
|
// const decrypted = decryptData(encryptedData, key);
|
||||||
|
// console.log(decrypted); // 输出解密后的数据
|
Loading…
Reference in new issue