一个面向 Java 反序列化测试的桌面 GUI 工具

工具介绍

YsoGUI一个面向 Java 反序列化测试的桌面 GUI 工具。

当前项目主要围绕:

  • ysoserial
  • marshalsec
  • Y4er 扩展的 CLASS: 模板

做统一的可视化封装。

工具使用

bash 复制代码
java -jar target/YsoGUI-1.0.0.jar

首次启动后:

  1. 加载 ysoserial.jar
  2. 如需 JNDI Reference / LDAP 反序列化,再加载 marshalsec.jar

当前功能

1. Payload 生成

支持从 ysoserial.jar 动态扫描链并生成 payload。

支持输出格式:

  • Base64
  • Gzip+Base64
  • URL 编码
  • Base64+URL 编码
  • Hex
  • Hex Dump
  • Raw

支持:

  • 普通命令参数
  • CLASS:模板名
  • 自定义 ObjectPayload

2. Exploit 模块

当前保留并可用的利用方式:

  • RMI Registry
  • JRMP Listener
  • JNDI / LDAP Remote Reference
  • JNDI / LDAP 反序列化
  • JNDI / RMI Remote Reference

当前 不提供

  • JNDI / RMI 反序列化

原因很简单:这条路径实现复杂、稳定性差,当前版本不作为正式功能提供。


3. JNDI 模式说明

LDAP

支持两种模式:

  • 远程 Reference(6u211 / 7u201 / 8u191 / 11.0.1)
  • 反序列化
RMI

只保留一种模式:

  • 远程 Reference(6u132 / 7u122 / 8u113)

4. 调用图编辑

支持:

  • 查看内置链调用图
  • 编辑节点/连边
  • 保存用户自定义图
  • 重置为内置图

5. 自定义链

支持导入你自己写的 ObjectPayload 实现类。

要求:

  • 必须实现 ysoserial.payloads.ObjectPayload
  • 导入的是已编译好的 .class

6. 内存马相关

项目里保留了内置模板 / 内存马相关管理代码,但当前版本 不建议作为主功能使用

原因:

  • 这部分兼容性强依赖具体链、容器和目标环境
  • 不同链对 TemplatesImpl / class 字节码加载路径并不一致
  • 工程上很难承诺"任意模板、任意容器、任意版本"都稳定

所以当前更推荐的用法是:

  • 把它当成辅助能力
  • 优先使用已经验证过的 payload / JNDI 路径
  • 不把内存马部分当成当前版本的稳定能力

工具下载

复制代码
https://github.com/wr0ld/YsoGUI
相关推荐
xieliyu.1 小时前
Java手搓二叉树:基础遍历与核心操作全解析
java·开发语言·数据结构·学习
luck_bor1 小时前
题目描述:综合题
java
Halo_tjn2 小时前
基于异常处理机制 相关知识点
java·开发语言·算法
likerhood2 小时前
java设计模式 · 适配器模式 (Adapter Pattern)
java·设计模式·适配器模式
snakeshe10102 小时前
SpringBoot 多人协作平台实战(6):SpringBoot Controller 入门与登录模块开发
java
用户298698530142 小时前
用 Java 操作 Word 文档?试试添加内容控件
java·后端
带刺的坐椅2 小时前
Java AI 框架三国杀:Solon AI vs Spring AI vs LangChain4j 深度对比
java·ai·langchain4j·spring-ai·solon-ai
苍煜2 小时前
K8s 集群快速搭建(系列第八篇:单机/多节点集群实战)
java·容器·kubernetes