簡體   English   中英

將方面編織到可執行jar並運行它

[英]Weaving aspect to executable jar and running it

我編寫了一個方面來在任何方法調用任何其他方法時打印有關方法的詳細信息。 我想排除Java庫。

我正在嘗試將方面編織到jAR文件中,然后執行JAR。

我掙扎了很長時間,閱讀了許多教程,但無法完成任務。

這是方面的代碼

import org.aspectj.lang.Signature;


public aspect MethodCallProfile {

    pointcut tracedCall() : call (* *(..)) && ! within(MethodCallProfile)  ;

    pointcut exclude() : execution(* java*(..)) && !within(MethodCallProfile)  ;
    before() : tracedCall() && exclude() {
        Signature sig = thisJoinPointStaticPart.getSignature();
        String line = ""
                + thisJoinPointStaticPart.getSourceLocation().getLine();

        String sourceName = thisJoinPointStaticPart.getSourceLocation()
                .getWithinType().getCanonicalName();
        //
        System.out.println("Call from " + sourceName + " line " + line + "\n   to "
                + sig.getDeclaringTypeName() + "." + sig.getName() +"\n");
    }

}

我用來生成編織jar的命令

ajc -injars dacapo-9.12-bach.jar aspects/MethodCallProfile.aj -outjar weaved_aspect.jar -classpath "aspectjrt.jar" -Xlintfile ajc.properties

我嘗試執行編織的JAR的命令

aj -cp .;;d:\dacapo\lib\aspectjweaver.jar -jar weaved_dacapo.jar avrora

java -cp d:\dacapo\lib\aspectjrt.jar;d:\dacapo\lib\aspectjtools.jar;d:\dacapo\lib\aspectjweaver.jar;d:\dacapo\lib\org.aspectj.matcher.jar -jar weaved_dacapo.jar avrora

錯誤

Exception in thread "main" java.lang.NoClassDefFoundError: 

org/aspectj/lang/Signature
        at java.lang.Class.getDeclaredMethods0(Native Method)
        at java.lang.Class.privateGetDeclaredMethods(Class.java:2521)
        at java.lang.Class.getMethod0(Class.java:2764)
        at java.lang.Class.getMethod(Class.java:1653)
        at sun.launcher.LauncherHelper.getMainMethod(LauncherHelper.java:494)
        at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:486)
Caused by: java.lang.ClassNotFoundException: org.aspectj.lang.Signature
        at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
        ... 6 more

Ajc.properties文件(由於找不到某些類型而出現錯誤。

cantFindType = warning

我的問題解決了。 我閱讀了Aspect1.8目錄中的自述文件,並按照步驟進行操作。

我將aspectjrt.jar復制到jdk/jre/lib/ext目錄,並將aspectjrt.jar添加到我的CLASSPATH環境變量中。

在編譯時,我添加了-cp。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM