私は実行時にクラスをロードし、この時点でいくつかのAspectJアスペクトでそれらを織り込もうとしています。ロードタイムウィービングを有効にしましたが、従来の方法で使用すると機能します。
@Aspectクラスには次のものがあります。
@Before("call(* mypackage.MyInterface.*())")
public void myInterfaceExecuteCall(JoinPoint thisJoinPoint,
JoinPoint.StaticPart thisJoinPointStaticPart,
JoinPoint.EnclosingStaticPart thisEnclosingJoinPointStaticPart) {
System.out.println(thisJoinPoint.getSignature().getDeclaringType());
System.out.println(thisJoinPoint.getSignature().getName());
}
次に、jarをスキャンして、次の実装であるクラスを見つけていますMyInterface
。
URLClassLoader classLoader = new URLClassLoader(new URL[] { urlOfJar },
ClassLoader.getSystemClassLoader());
WeavingURLClassLoader weaver = new WeavingURLClassLoader(
classLoader);
HashSet<Class<?>> executableClasses = new HashSet<Class<?>>();
for (String name : classNamesInJar) {
try {
Class<?> myImplementation = weaver.loadClass(name);
if (MyInterface.class.isAssignableFrom(myImplementation)) {
executableClasses.add(myImplementation);
}
} catch (Exception e) {
e.printStackTrace();
} catch (NoClassDefFoundError e) {
e.printStackTrace();
}
}
...そして、ある時点で、ロードされたクラスで特定のメソッドを実行しています。
try {
Method execute = myImplementation.getMethod("execute");
execute.invoke(myImplementation.newInstance());
} catch (Exception e) {
e.printStackTrace();
}
ただし、上記で示した@Beforeメソッドは、呼び出したときに実行されることはありませんexecute.invoke(...)
(ただし、execute
メソッド自体は明らかに実行されますが、その出力が表示されます)。
誰かが私が間違っていることを知っていますか?myInterfaceExecuteCall
ロードされたクラスのメソッドが呼び出される前にgetを呼び出す方法は何ですか?