news 2026/4/3 5:48:09

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/3/27 22:46:36

【建议收藏】一文搞懂大模型上下文工程:提示词工程的进阶指南

文章介绍了大模型上下文工程的基础概念,解析其与提示词工程的互补关系。上下文工程由三大组件构成:上下文获取与生成(提示词工程、外部知识检索、动态上下文组装)、上下文处理(长上下文处理、多模态整合等)…

作者头像 李华
网站建设 2026/4/1 13:06:09

7款AI论文写作神器,结合LaTeX模板轻松满足格式要求

工具快速对比(7大AI论文工具TOP排名) 这7款工具覆盖论文写作全流程,各有亮点: Aibiye:智能成文与无限改稿,适合初稿优化(��)。 Aicheck:一键生…

作者头像 李华
网站建设 2026/4/1 0:20:30

基于51单片机超声波测距仪倒车雷达汽车防撞系统仿真(程序+仿真+原理图+设计报告等等全套资料)

基于51单片机超声波测距仪倒车雷达汽车防撞系统仿真(程序仿真原理图设计报告等等全套资料)测距原理: 利用单片机控制定时计数器来记录超声波从发射到接收的往返时间,从而计算出实际距离。采用温度补偿算法,提高测距精度。 硬件组成: 超声波发射接收电路、…

作者头像 李华