Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/echo094/decode-js
JS混淆代码的AST分析工具 AST analysis tool for obfuscated JS code
https://github.com/echo094/decode-js
javascript-deobfuscator obfuscator
Last synced: 13 days ago
JSON representation
JS混淆代码的AST分析工具 AST analysis tool for obfuscated JS code
- Host: GitHub
- URL: https://github.com/echo094/decode-js
- Owner: echo094
- License: mit
- Created: 2022-09-13T06:37:40.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-11-24T16:24:15.000Z (about 2 months ago)
- Last Synced: 2024-11-24T17:25:33.723Z (about 2 months ago)
- Topics: javascript-deobfuscator, obfuscator
- Language: JavaScript
- Homepage:
- Size: 301 KB
- Stars: 710
- Watchers: 8
- Forks: 334
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hacking-lists - echo094/decode-js - JS混淆代码的AST分析工具 AST analysis tool for obfuscated JS code (JavaScript)
README
# decode-js
基于 Babel 的 AST 分析器和处理器,可以处理以下情况:
* stringArray(包括添加了旋转操作,以及嵌套调用的情况)
* 死代码
* 控制流扁平化(switch)
* 局部代码变换(Object表达式、字符串分割等)
* 自定义代码(自保护,禁止控制台调试,禁止控制台输出)An AST analyzer and processor based on Babel that can handle the following situations:
* stringArray (including Rotate, Wrappers, and ChainedCalls)
* deadCode
* controlFlowFlattening (switch)
* transformer (ObjectExpression, SplitString, and etc.)
* customCode (self-defending, debug-protection, console-output)## 使用 Usage
**如果在安装和运行过程中出现问题,请先排查[isolated-vm](https://github.com/laverdet/isolated-vm?tab=readme-ov-file#requirements)的安装和使用要求**
**If problems occur during installation and execution, please check the requirements of [isolated-vm](https://github.com/laverdet/isolated-vm?tab=readme-ov-file#requirements) first**
1. 准备一个nodejs环境 (16.x以上 推荐18.x)
Prepare a nodejs environment (>=16.x and 18.x is suggested)
2. 通过`npm i`安装依赖
Install the dependencies via `npm i`
3. 按如下方式运行插件:Run the plugins as follows:
```shell
# pre-defined command
npm run xxx
# or full command
npm run decode -- -t type [-i input.js] [-o output.js]
````xxx`为预定义的指令,见[package.json](package.json)中的`scripts`字段。
`xxx` are predefined commands, see the `scripts` field in [package.json](package.json).
`type`:
* common (高频局部混淆)
* jjencode (sojson.com 版本)
* sojson
* sojsonv7
* obfuscator默认输入文件为`input.js`,文件中不能包含除混淆代码以外的内容(例如非混淆代码)。
The default input file is `input.js`. The file cannot contain additional codes other than obfuscated code (such as non-obfuscated code).
默认输出文件为`output.js`。
The default output file is `output.js`.
## Related Projects
* [cilame/v_jstools](https://github.com/cilame/v_jstools)
* [j4k0xb/webcrack](https://github.com/j4k0xb/webcrack)
* [NXY666/Jsjiemi](https://github.com/NXY666/Jsjiemi)