Home

Awesome

<h4 align="right"><strong><a href="jmg-docs/README_EN.md">English</a></strong> | 中文 </h4> <p align="center"> <h1 align="center">Java Memshell Generator</h1> <div align="center"> <img alt="GitHub watchers" src="https://img.shields.io/github/watchers/pen4uin/java-memshell-generator?style=flat-square"> <img alt="GitHub forks" src="https://img.shields.io/github/forks/pen4uin/java-memshell-generator?style=flat-square"> <img alt="GitLab Stars" src="https://img.shields.io/github/stars/pen4uin/java-memshell-generator.svg?style=flat-square"> </div> <div align="center">一款支持高度自定义的 Java 内存马生成工具</div> </p> <img src="./jmg-docs/img/gui.png" width="900px" /> <br>

[!WARNING] 本工具仅供安全研究和学习使用。使用者需自行承担因使用此工具产生的所有法律及相关责任。请确保你的行为符合当地的法律和规定。作者不承担任何责任。如不接受,请勿使用此工具。

<br>

功能

中间件框架工具 (测试版本)内存马类型输出格式辅助模块
TomcatSpringMVCAntSword (2.1.15)ListenerBASE64专项漏洞封装
ResinSpringWebFluxBehinder (4.0.7)FilterBCEL表达式语句封装
WebLogicGodzilla (4.0.1)InterceptorBIGINTEGER
JettyNeo-reGeorg (5.1.0)HandlerMethodCLASS
WebSphereSuo5 (0.9.0)TomcatValveJAR
UndertowCustomJAR_AGENT
GlassFishJS
JSP

编译

maven (v3.9.3)

mvn package assembly:single

使用

图形化

java -jar ./releases/jmg-gui-1.0.8.jar

命令行

java -jar ./releases/jmg-cli-1.0.8.jar

Woodpecker 插件

将 jmg-woodpecker-1.0.8.jar 添加到 woodpecker 插件目录

第三方库 (Maven)

1.将 jmg-sdk-1.0.8.jar 安装到本地 maven 仓库

mvn install:install-file -Dfile=./releases/jmg-sdk-1.0.8.jar -DgroupId=jmg -DartifactId=jmg-sdk -Dversion=1.0.8 -Dpackaging=jar

2.添加为依赖

<dependency>
    <groupId>jmg</groupId>
    <artifactId>jmg-sdk</artifactId>
    <version>1.0.8</version>
</dependency>

3.示例

// 基础配置
AbstractConfig config = new AbstractConfig() {{
    // 设置工具类型
    setToolType(Constants.TOOL_GODZILLA);
    // 设置中间件 or 框架
    setServerType(Constants.SERVER_TOMCAT);
    // 设置内存马类型
    setShellType(Constants.SHELL_LISTENER);
    // 设置输出格式为 BASE64
    setOutputFormat(Constants.FORMAT_BASE64);
    // 设置漏洞利用封装,默认不启用
    setGadgetType(Constants.GADGET_NONE);
    // 初始化基础配置
    build();
}};

jMGenerator generator = new jMGenerator(config);
generator.genPayload();
generator.printPayload();

// 连接信息
SDKResultUtil.printBasicInfo(config);
SDKResultUtil.printDebugInfo(config);

文档

致谢

协议