开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 85|回复: 1
打印 上一主题 下一主题
收起左侧

[其它求助] CryptoJS 怎么改呀大神们!

[复制链接]
结帖率:50% (1/2)
跳转到指定楼层
楼主
发表于 4 天前 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式   浙江省衢州市
9精币
  
const CryptoJS = require ( ' crypto-js');
const pako = require ( ' pako');
/**
* 十六进制字符串转Uint8Array
* [url=home.php?mod=space&uid=275307]@param[/url] {string} hexStr - 十六进制字符串
* @returns {Uint8Array} 转换后的字节数组
*/
function hexToUint8Array (hexStr) {
// 移除可能的空格
hexStr = hexStr.replace (/\s/g, ' ');
if (hexStr.length % 2 !== 0) {
throw new Error ( ' 十六进制字符串长度必须为偶数');
}
const bytes = new Uint8Array (hexStr.length / 2);
for (let i = 0; i < bytes.length; i++) {
const twoChars = hexStr.substr (i * 2, 2);
bytes[i] = parseInt (twoChars, 16);
}
return bytes;
}
/**
* Uint8Array转WordArray
* @param {Uint8Array} uint8Array - 字节数组
* @returns {CryptoJS.lib.WordArray} CryptoJS的WordArray
*/
function uint8ArrayToWordArray (uint8Array) {
const words = [];
for (let i = 0; i < uint8Array.length; i++) {
words[i >>> 2] |= (uint8Array[i] & 0xff) << (24 - (i % 4) * 8);
}
return CryptoJS.lib.WordArray.create (words, uint8Array.length);
}
/**
* WordArray转Uint8Array
* @param {CryptoJS.lib.WordArray} wordArray - CryptoJS的WordArray
* @returns {Uint8Array} 字节数组
*/
function wordArrayToUint8Array (wordArray) {
const bytes = new Uint8Array (wordArray.sigBytes);
for (let i = 0; i < bytes.length; i++) {
bytes[i] = (wordArray.words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;
}
return bytes;
}
/**
* 解密十六进制密文
* @param {string} hexCiphertext - 十六进制密文
* @param {CryptoJS.lib.WordArray} key - 解密密钥
* @returns {string} 解密后的内容
*/
function decryptHex (hexCiphertext, key) {
try {
// 1. 十六进制转字节数组
const cipherBytes = hexToUint8Array (hexCiphertext);
console.log ( ' [解密] 密文字节长度:', cipherBytes.length);
// 2. 字节数组转WordArray
const cipherWordArray = uint8ArrayToWordArray (cipherBytes);
// 3. AES-CBC解密(假设使用与之前相同的参数)
const decryptedWordArray = CryptoJS.AES.decrypt (
{ ciphertext: cipherWordArray },
key,
{
iv: key, // IV=密钥(与之前加密逻辑一致)
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7
}
);
// 4. 解密结果转字节数组
const decryptedBytes = wordArrayToUint8Array (decryptedWordArray);
console.log ( ' [解密] 解密后字节长度:', decryptedBytes.length);
console.log ( ' [解密] 前2字节:', decryptedBytes.slice(0, 2));
// 5. 尝试gzip解压
let resultBytes;
try {
resultBytes = pako.ungzip (decryptedBytes);
console.log ( ' [解密] gzip解压成功,长度:', resultBytes.length);
} catch (e) {
console.log ( ' [解密] 非gzip格式,直接处理');
resultBytes = decryptedBytes;
}
// 6. 转字符串
return new TextDecoder ( ' utf-8').decode(resultBytes);
} catch (error) {
console.error ( ' [解密] 失败:', error.message);
return null;
}
}
// ------------------------------
// 配置参数
// ------------------------------
const config = {
// 十六进制密文
hexCiphertext: "215C133DFC2013CA85D18C62D075E3A20BA605FD4285D33A3EE3DEC7E2F1CCCD1099FC108D5129CE5D7DC26288C555E07F4429C95A3E28910CA9E77D064B69FCC4E284CE08C5A9BA2F8D92623A1EB2F79DCE7E09285989ACBBAA2474C559E2A5A9906F8AA774A0F56B32A5163F79EE9AF0A26DCC8040409751A3FF5012F13BE3DC382768C96E404D92E7C5026D160B420F6CDA470DA90B84E291B5BB7F81D16454A0497B10E3A1BDA47E1B44D71BD9AA8788F3CE0512AE5F3B63F38AFB1D80A69863C06FF549D5960508FC00261A105B576555163D5175684D3C89D24A7DFD12571353806E8E202B2F1D4E2EDAA6EDC3DBB8B012F56A16C6BC233F2C9746EBAE34B8E10255719A69D26F374DEADFFFBE120E3460B1FDB886C246EC0507A53FC34715F6B9B09C66E2E4289A92ACAF131CEB7CD24E364136D92750D18D6CB08AA18A4ED5842F27768013C91ED6CBC500563F236CFC4B5B0735F679949C3ACFB1670333271DE981C67B26A779823834694047254FD74C1C4271FA3666544EB93ADF5DA2729F421D0797CECFDF48DE588E6B0C6F70EE1CD1DD549646F96BBB7B34D8EB4CE5E43FE6DE4B528CD3655C6F1FD0D9763C55D0DD986D6A135F61627645DBF566A3A51E207978AB6F7958E35E58FD57BB7C8A9D0ECF00733822B2E05220EE7F1FF5F7D53921C08170B57DCD0456FF4B2387F39ACAC5110A59AB947F3DA13FFE3D72FC93BB3A59F04C008F707392684C796D960282ED2CC2141635304524869FE405BE32A752FEC50D7D90979E4F664CA6AA03125CCAD9B657211BEADDCB611CA0C47A5D08DC52C15E3FE31AB63F25904CFB93BE72FAA4834EC1871B8E509872E6CF1D8C8AD0A75A28534A662930B311DFC3D9F5C5F8844FF46723EEA55890895586ABCBBB3F90DAF1C10CDE1FD0655EFE858FA400B92095A46383DA89EAE583ED1486AB3554A0731C5B54C403EB81",


// 请替换为实际加密密钥(示例为之前的密钥格式)
key: CryptoJS.lib.WordArray.create (
[1162098497, 1093678658, 1144534578, 943863093], // 替换为实际密钥的words数组
16 // 密钥长度(16字节=128位,32字节=256位)
)
};
// ------------------------------
// 执行解密ac
// ------------------------------
const result = decryptHex (config.hexCiphertext, config.key);
if (result) {
console.log ( ' \n===== 解密结果 =====');
console.log (result);
// 尝试解析为JSON
try {
const jsonResult = JSON.parse (result);
console.log ( ' \n===== JSON格式化结果 =====');
console.log (JSON.stringify (jsonResult, null, 2));
} catch (e) {
console.log ( ' \n解密结果不是JSON格式');
}
}
Visual Studio Code



回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:50% (1/2)

签到天数: 12 天

沙发
 楼主| 发表于 3 天前 | 只看该作者   浙江省衢州市
谢谢,已解决
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:[email protected]
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表