多读书多实践,勤思考善领悟

Java逆向基础之十五.初识javaagent

本文于2131天之前发表,文中内容可能已经过时。

首先说一下javaagent是什么

javaagent是一种能够在不影响正常编译的情况下,修改字节码。

在逆向中javaagent可以完成对类的拦截和增强。

看一个例子

在Eclipse新建如下MyAgent结构的项目

QQ截图20180423085023.png

MyAgent.java文件内容

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
package com.vvvtimes.demo.agent;

import java.lang.instrument.Instrumentation;

public class MyAgent {

public static void premain(String agentOps, Instrumentation inst) {
System.out.println("=========premain参数个数为2方法执行========,My agentOps = [" + agentOps + "].");
System.out.println(agentOps);
}

public static void premain(String agentOps) {
System.out.println("=========premain参数个数为1方法执行========,My agentOps = [" + agentOps + "].");
System.out.println(agentOps);
}
}

MANIFEST.MF文件内容

1
2
3
Manifest-Version: 1.0
Premain-Class: com.vvvtimes.demo.agent.MyAgent
Can-Redefine-Classes: true
  • 注意:这里的Premain-Class必须指向premain方法所在的类

在Eclipse导出jar的时候需要手动指定这个文件

QQ截图20180423085313.png

我们将导出的jar命名为MyAgent.jar

再建立一个名为MyProgram的工程

代码如下

1
2
3
4
5
6
7
8
package com.vvvtimes.demo;

public class MyProgram {
public static void main(String[] args) {
System.out.println("=========main方法执行========");
}

}

导出可运行jar,命名为MyProgram.jar

将这两个jar放到同一目录(我是放到桌面)

cd切换到该目录后执行

1
java -javaagent:MyAgent.jar=helloworld -jar MyProgram.jar

运行结果如下

1
2
3
4
C:\Users\admin\Desktop>java -javaagent:MyAgent.jar=helloworld -jar MyProgram.jar
=========premain参数个数为2方法执行========,My agentOps = [helloworld].
helloworld
=========main方法执行========

可以看到main方法执行前执行了premain方法里的两个输出语句

javaagent参数选项

1
java -javaagent:agentjar 文件的位置 [= 传入 premain 的参数 ] -jar 要运行的jar文件