gpt4 book ai didi

java - AspectJ 切入点不适用于外部类和 LTW

转载 作者:太空宇宙 更新时间:2023-11-04 08:30:42 27 4
gpt4 key购买 nike

我正在尝试将 AspectJ(直到昨天我才知道)与 LTW 一起使用,以了解如何 an existing framework作品。简而言之,我对如何解析框架的输入 XML 文件感兴趣。

我写了以下方面:

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.reflect.CodeSignature;

public aspect UnitContextTrace {

static final void println(String s){ System.out.println(s); }

pointcut unitContextMethodsExec(): call(public * org.ivalidator.framework.test.UnitContext.* (..)) ||
call(public void org.ivalidator.repository..*.set* (..));

Object around(): unitContextMethodsExec() {
println("Intercepted message: " +
thisJoinPointStaticPart.getSignature().getName());
println("in class: " +
thisJoinPointStaticPart.getSignature().getDeclaringType().getName());
printParameters(thisJoinPoint);
println("Running original method: \n" );
Object result = proceed();
println(" result: " + result );
return result;
}

static private void printParameters(JoinPoint jp) {
println("Arguments: " );
Object[] args = jp.getArgs();
String[] names = ((CodeSignature)jp.getSignature()).getParameterNames();
Class[] types = ((CodeSignature)jp.getSignature()).getParameterTypes();
for (int i = 0; i < args.length; i++) {
println(" " + i + ". " + names[i] +
" : " + types[i].getName() +
" = " + args[i]);
}
}
}

这应该调试对 UnitContext 接口(interface)实现的方法的调用以及对属于 org.ivalidator.repository.* 包的任何类的 setXXX() 方法的调用。

我使用以下方式将我的 Aspect 打包到自己的 jar 中

 ajc UnitContextTrace.aj -outxml -outjar aspectTrace.jar -extdirs "C:\aspectj1.6\lib\"

然后我启动了程序(我使用 ant 脚本),将 -javaagent:${aspectj.home}/lib/aspectjweaver.jar 传递到 JVM。

方面的第一部分(UnitContext 方法)有效,我可以看到例如

Intercepted message: getAdapter…

但不幸的是,没有调用 setXXX() 方法的日志。 org.ivalidator.repository.* 包是 ivalidator.jar 的一部分,它当然使用存储在 lib 文件夹中的第 3 方库。结构是这样的:

  • Ivalidator.jar
  • /lib
    • Castor-0.9.7.jar
    • xercesImpl.jar

使用调试器,我注意到 setXXX() 方法是从外部类(属于 castor-0.9.7.jar,该类又由 xerces 的类调用)调用的。更准确地说,我在调试器中看到的堆栈跟踪是这样的:

**ParameterXml.setName(String) line: 60 (I want to intercept this)**
NativeMethodAccessorImpl.invoke0(Method, Object, Object[]) line: not available [native method]
NativeMethodAccessorImpl.invoke(Object, Object[]) line: not available
DelegatingMethodAccessorImpl.invoke(Object, Object[]) line: not available
Method.invoke(Object, Object...) line: not available
FieldHandlerImpl.setValue(Object, Object) line: 501
UnmarshalHandler.processAttribute(String, String, String, XMLFieldDescriptor, XMLClassDescriptor, Object) line: 3028
UnmarshalHandler.processAttributes(AttributeSet, XMLClassDescriptor) line: 2702
UnmarshalHandler.startElement(String, String, AttributeSet) line: 2325
UnmarshalHandler.startElement(String, String, String, Attributes) line: 1388
SAXParser(AbstractSAXParser).startElement(QName, XMLAttributes, Augmentations) line: not available
SAXParser(AbstractXMLDocumentParser).emptyElement(QName, XMLAttributes, Augmentations) line: not available
XMLNSDocumentScannerImpl.scanStartElement() line: not available
XMLNSDocumentScannerImpl$NSContentDispatcher(XMLDocumentFragmentScannerImpl$FragmentContentDispatcher).dispatch(boolean) line: not available
XMLNSDocumentScannerImpl(XMLDocumentFragmentScannerImpl).scanDocument(boolean) line: not available
XML11Configuration.parse(boolean) line: not available
XML11Configuration.parse(XMLInputSource) line: not available
SAXParser(XMLParser).parse(XMLInputSource) line: not available
SAXParser(AbstractSAXParser).parse(InputSource) line: not available
**DescriptorRepositoryXml(XmlObject).fromXml(InputSource) line: 341 (last call within ivalidator.jar)**

我想知道对外部类(外部 jar 以及 org.xml.sax.xmlreader)的调用是否可能会导致问题?

最佳答案

我猜你不想拦截call(),而是拦截execution()。在这种情况下,您的第三方类是否编织并不重要。

关于java - AspectJ 切入点不适用于外部类和 LTW,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7595219/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com