(实验性)基于AST的jsjiami.com代码混淆清除

目前支持

  1. JS最牛加密-V6
    • 状态:测试通过免费版最高配置
  2. SOJSON-V5版
    • 状态:测试通过免费版最高配置

清除效果

  • 清除字符串加密
  • 清除运算符、函数调用混淆
  • 清除无效代码块
  • 清除函数执行过程混淆

测试示例

使用须知

  • 解密文件中必须有且仅有通过JsjiamiV6或SOJSON-V5版加密的内容,且不允许格式化,否则将解密失败。
  • 解密器会使用vm(虚拟机)执行JS中的部分代码(在一般情况下,它会被用来执行JsjiamiV6生成的解密函数)。
  • 由于注释及部分变量名在代码压缩、混淆的过程中已经丢失或被篡改,此类信息无法复原。
  • 如果该JS过于复杂使用了(我)不常用的语法,可能导致解密失败,如遇到此类情况欢迎提出。
  • 由于使用了AST,直接对语法树进行操作,可能导致代码与实际不符,结果仅供参考,如遇解密出错情况欢迎提出。
    • 提示:结果的正确性随操作步骤叠加而逐渐降低

使用方法

  1. decryptor.js 的常量 FILE_NAME 中填写需解密的脚本路径。
  2. 运行 decryptor.js

输出结果

每一解密步骤完成后,解密器都会输出一个结果文件。

您可以根据您的需求从以下版本中选择一个作为最终解密结果。

  • clear_encrypt_str.js:解除全局字符加密
  • clear_encrypt_operate.js:解除运算及调用加密、清理死代码(if-else)
  • clear_function_execution_step_confusion.js:去除函数执行步骤混淆

参考

本项目参考了下面的项目:

  1. NXY666/Jsjiemi