【发布时间】:2017-07-16 06:46:11
【问题描述】:
我有一个代理 JAR(jar-with-dependencies),其 premain 为
public static void premain(String args, Instrumentation instrumentation) {
log.info("Starting Swing Testing Tools");
log.info("Adding global listener using agent");
Toolkit.getDefaultToolkit().addAWTEventListener(new GlobalEventListener(), GlobalEventListener.WINDOW_MASK);
log.info("Starting server");
Thread serverThread = new Thread(new InterceptorServer());
serverThread.start();
}
这是一个拦截器 JAR,它将侦听所有事件。此类还包含一个 main 方法。此 JAR 的目的是拦截 JNLP,以便我们可以触发所有事件。
现在,当我使用以下命令运行此 JAR 时,代理工作正常。
D:\temp>java -jar ListenerAgent-1.0.jar
20170716,12.04.49 [INFO ] - (la.core.Agent.premain(Agent.java:16)) Starting Swing Testing Tools
20170716,12.04.49 [INFO ] - (la.core.Agent.premain(Agent.java:17)) Adding global listener using agent
20170716,12.04.49 [INFO ] - (la.core.Agent.premain(Agent.java:20)) Starting server
20170716,12.04.49 [INFO ] - (la.core.server.InterceptorServer.run(InterceptorServer.java:30)) Server started at port : 50173
C:\Users\GAGAND~1\AppData\Local\Temp\
但是当我使用以下命令行参数启动它时,代理没有响应但 JNLP 会打开。
D:\temp>javaws -J-javaagent:"D:\temp\ListenerAgent-1.0.jar" "D:\JNLPs\Notepad.jnlp"
D:\temp>
这是清单文件:
Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Created-By: Apache Maven
Built-By: Gagandeep Singh
Build-Jdk: 1.8.0_111
Specification-Title: ListenerAgent
Specification-Version: 0.0.1-SNAPSHOT
Implementation-Title: ListenerAgent
Implementation-Version: 0.0.1-SNAPSHOT
Implementation-Vendor-Id: org.gagan
Main-Class: la.core.Agent
Can-Redefine-Classes: false
Can-Retransform-Classes: true
Premain-Class: la.core.Agent
这是我的存储库的link,以防您需要查找任何其他信息。
【问题讨论】:
标签: java swing javaagents spy