news 2026/5/1 8:15:55

CryptoJS AES 解密完整实战示例(Python + execjs)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CryptoJS AES 解密完整实战示例(Python + execjs)

本文通过一个完整、可运行的示例,演示如何在Python 中使用 execjs 调用 CryptoJS 实现 AES 解密
适合:接口逆向、数据采集、前端加密分析等场景。


一、最终效果说明

我们要实现的效果是:

  • 前端(JS)用CryptoJS AES-CBC加密 JSON
  • Python 通过execjs 调用 JS 解密
  • 最终在 Python 中拿到原始 JSON 数据

二、准备环境

1️⃣ 安装 Node.js

node-v

如果没有:

sudoaptinstallnodejsnpm

2️⃣ 安装 Python 依赖

pipinstallPyExecJS

3️⃣ 安装 CryptoJS(JS 依赖)

在项目目录下执行:

npminit -ynpminstallcrypto-js

三、项目目录结构

aes-demo/ ├── encrypt.js # (模拟前端)AES 加密 ├── decrypt.js # CryptoJS 解密函数 ├── decrypt.py # Python 调用 execjs └── cipher.txt # AES 密文

四、模拟前端 AES 加密(encrypt.js)

这一步是为了生成真实密文,方便你测试
实际项目中,这一步通常是网站前端完成的

constCryptoJS=require("crypto-js");constkey="1234567890abcdef";// 16 字节constiv="abcdef1234567890";// 16 字节constdata={user:"admin",age:18,role:"tester"};constplaintext=JSON.stringify(data);constencrypted=CryptoJS.AES.encrypt(plaintext,CryptoJS.enc.Utf8.parse(key),{iv:CryptoJS.enc.Utf8.parse(iv),mode:CryptoJS.mode.CBC,padding:CryptoJS.pad.Pkcs7}).toString();console.log(encrypted);

运行:

nodeencrypt.js>cipher.txt

此时cipher.txt中就是 AES 密文。


五、CryptoJS 解密函数(decrypt.js)

⚠️execjs 只能调用全局函数

constCryptoJS=require("crypto-js");functiondecryptData(key,iv,ciphertext){constdecrypted=CryptoJS.AES.decrypt(ciphertext,CryptoJS.enc.Utf8.parse(key),{iv:CryptoJS.enc.Utf8.parse(iv),mode:CryptoJS.mode.CBC,padding:CryptoJS.pad.Pkcs7});returndecrypted.toString(CryptoJS.enc.Utf8);}

六、Python 调用 JS 解密(decrypt.py)

这是核心代码👇

importexecjsimportjsondefaes_decrypt(ciphertext):key="1234567890abcdef"iv="abcdef1234567890"withopen("decrypt.js","r",encoding="utf-8")asf:js_code=f.read()ctx=execjs.compile(js_code)plaintext=ctx.call("decryptData",key,iv,ciphertext)returnplaintextif__name__=="__main__":# 读取密文withopen("cipher.txt","r",encoding="utf-8")asf:cipher=f.read().strip()result=aes_decrypt(cipher)print("解密后的字符串:")print(result)print("\n解析为 JSON:")data=json.loads(result)print(data)

七、运行结果示例

解密后的字符串: {"user":"admin","age":18,"role":"tester"} 解析为 JSON: {'user': 'admin', 'age': 18, 'role': 'tester'}

解密成功


八、关键点总结(一定要看)

🔹 1. key / iv / mode / padding 必须一致

任何一个不一致,都会:

  • 解密为空字符串
  • JSON 解析失败

🔹 2. execjs 本质是「Python → Node」

所以:

  • Node.js 必须可用
  • crypto-js 必须能被require

🔹 3. 解密失败先不要json.loads

先:

print(result)

九、常见问题速查

❌ 解密结果为空

✔ key / iv 错
✔ AES 模式不一致
✔ padding 不一致


❌ 报错 Cannot find module ‘crypto-js’

npminstallcrypto-js

❌ execjs 报 RuntimeUnavailableError

说明Node.js 没装或不可用


十、适用场景

这个方案非常适合:

  • Web 接口 AES 逆向
  • 前端加密参数分析
  • Python 自动化解密
  • 不想手写 AES 算法
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:49:59

桥式起重机毕业设计

2.大车运行机构的设计 2.1设计的基本原则和要求 大车运行机构的设计通常和桥架的设计一起考虑,两者的设计工作要交叉进行,一般的设计步骤: 确定桥架结构的形式和大车运行机构的传方式布置桥架的结构尺寸安排大车运行机构的具体位置和尺寸综合…

作者头像 李华
网站建设 2026/5/1 6:49:24

工厂供电系统

第二章 负荷计算及无功补偿 2.1 负荷计算 需要系数法。用设备功率乘以需要系数和功率因数,直接求出计算负荷。这种方法比较简单,应用广泛,尤其适用于配、变电所的负荷计算。使用范围:当用电设备台数较多、各台设备容量相差不太悬殊…

作者头像 李华
网站建设 2026/5/1 7:10:44

无刷直流电机BLDC双闭环调速系统仿真(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

无刷直流电机BLDC双闭环调速系统仿真(设计源文件万字报告讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码有报告和参考纹献 (1)DC直流源、三相逆变桥、无刷直流电机、PI控制器、PWM发生器、霍尔位置解码模块、驱动信号控制等 (2)采用转速和电流双闭…

作者头像 李华