DHook是一个支持动态debug,动态修改java web应用类的参数,返回值等的web应用.
git clone https://github.com/keven1z/DHook.git
,根目录运行mvn clean package
或者直接下载release包- 本地运行
java -jar DHookServer-[release-version].jar
# http 端口:8081
# websocket 端口:7070
在待测试应用运行时加入-javaagent:{path}/dHook.jar
运行参数。
点击添加hook点,输入待hook的classname和method,即可进行hook
点击hook点详情,即可查看hook点入参,返回值以及调用栈信息。
以破解cs4.4为例,我们已知破解cs 需要修改common/Authorization
中的以下参数:
- validto 有效期
- valid 有效性
以及调用
common/SleevedResource.Setup
传入密钥即可。 我们在方法执行前加入对应的参数和对应破解的值,并执行common/SleevedResource.Setup
静态方法,最后加入return
,使<init>
方法执行返回。
- 插件离线化
- 自定义配置文件
- 检测插件
- 动态辅助漏洞测试
- 增加心跳包断线重连
- 增加类图 类详细信息查看以及源码下载功能
- 增加hook点调用参数,调用栈等信息展示
- 增加自定义ip配置功能
- 增加hook library功能
- 更新插件编写规则
- 更新ui(凑合能看)
- 补充修改应用名和hook点信息的功能
- 增加插件功能
- 增加导出仅包含hook点信息的agent
- 可以增加方法执行前后静态方法执行参数
- 增加方法执行前后,直接return
- 增加交互式的hook操作
- 增加方法执行前后的修改
- 增加通过
*
打印该类的所有方法 - 支持打印返回值
- 支持反编译代码
- 支持修改参数
- 支持hook接口,当填写的类为接口时,默认会hook所有实现的子类
- 支持更改hook类的返回类型为string,int,boolean的返回值
- 支持打印hook方法的所有参数值