java - AspectJ 示例项目中出现错误

标签 java aop aspectj aspectj-maven-plugin

我是aspectJ 的新手。我在 Aspect 类中遇到编译错误。当我运行该项目时,我收到编译错误。请帮我。将获得的代码片段和错误放在下面:

项目结构:

enter image description here

MannersAspect.java

package main.java.testaop;

public aspect MannersAspect {
    pointcut callSayMessage() :
        call(public static void HelloWorld.say*(..));
    before() : callSayMessage() {
        System.out.println("Good day!");
    }
    after() : callSayMessage() {
        System.out.println("Thank you!");
    }
}

HelloWorld.java

package main.java.testaop;

public class HelloWorld {
    public static void say(String message) {
        System.out.println(message);
    }
    public static void sayToPerson(String message, String name) {
        System.out.println(name + ", " + message);
    }
}

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.test</groupId>
    <artifactId>testaop</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>
    <name>testaop</name>

    <dependencies>                            
        <dependency>       
            <groupId>org.aspectj</groupId>    
            <artifactId>aspectjrt</artifactId>
            <version>1.8.4</version>          
        </dependency>                         
    </dependencies> 

    <build>
        <pluginManagement>
            <plugins>
                <!--This plugin's configuration is used to store Eclipse m2e settings only. It has no influence on the Maven build itself.-->
                <plugin>
                    <groupId>org.eclipse.m2e</groupId>
                    <artifactId>lifecycle-mapping</artifactId>
                    <version>1.0.0</version>
                    <configuration>
                        <lifecycleMappingMetadata>
                            <pluginExecutions>
                                <pluginExecution>
                                    <pluginExecutionFilter>
                                        <groupId>org.apache.maven.plugins</groupId>
                                        <artifactId>maven-compiler-plugin</artifactId>
                                        <versionRange>[2.5.1,)</versionRange>
                                        <goals><goal>compile</goal></goals>
                                    </pluginExecutionFilter>
                                    <action><ignore></ignore></action>
                                </pluginExecution>
                                <pluginExecution>
                                    <pluginExecutionFilter>
                                        <groupId>org.codehaus.mojo</groupId>
                                        <artifactId>aspectj-maven-plugin</artifactId>
                                        <versionRange>[1.7,)</versionRange>
                                        <goals><goal>compile</goal></goals>
                                    </pluginExecutionFilter>
                                    <action><ignore></ignore></action>
                                </pluginExecution>
                            </pluginExecutions>
                        </lifecycleMappingMetadata>
                    </configuration>
                </plugin>
            </plugins>
        </pluginManagement>

        <plugins>
            <plugin>                                                 
                <groupId>org.codehaus.mojo</groupId>            
                <artifactId>aspectj-maven-plugin</artifactId>        
                <executions>                                         
                    <execution>                                      
                        <goals><goal>compile</goal></goals>                                     
                        <configuration>                              
                            <source>1.5</source>                     
                            <target>1.5</target>                     
                        </configuration>                             
                    </execution>                                     
                </executions>                                        
            </plugin>
            <plugin>                                                 
                <groupId>org.codehaus.mojo</groupId>         
                <artifactId>exec-maven-plugin</artifactId>           
                <executions>                                         
                    <execution><goals><goal>java</goal></goals></execution>                                     
                </executions>                                        
                <configuration>                                      
                    <mainClass>main.java.testaop.HelloWorld</mainClass>            
                </configuration>                                     
            </plugin>
        </plugins>
    </build>
</project>

错误:

[ERROR] COMPILATION ERROR : 
[ERROR] D:\workspacedummy\testaop\src\main\java\testaop\MannersAspect.java:[3,7] error: class, interface, or enum expected
[ERROR] D:\workspacedummy\testaop\src\main\java\testaop\MannersAspect.java:[4,51] error: class, interface, or enum expected
[ERROR] D:\workspacedummy\testaop\src\main\java\testaop\MannersAspect.java:[4,72] error: malformed floating point literal
[ERROR] D:\workspacedummy\testaop\src\main\java\testaop\MannersAspect.java:[5,4] error: class, interface, or enum expected
[ERROR] D:\workspacedummy\testaop\src\main\java\testaop\MannersAspect.java:[7,4] error: class, interface, or enum expected
[ERROR] D:\workspacedummy\testaop\src\main\java\testaop\MannersAspect.java:[10,4] error: class, interface, or enum expected
[INFO] 6 errors 
[INFO] BUILD FAILURE
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:2.5.1:compile (default-compile) on project testaop: Compilation failure: Compilation failure:

最佳答案

您已经通过“New”->“Class”(因此是“.java”扩展名)在 Eclipse 中创建了切面,但您应该通过“New”->“Aspect”创建它(然后它将获得一个“.aj”扩展名)。

P.S.:您确实在 Eclipse 中安装了 AJDT(AspectJ 开发工具),不是吗? ;-)

P.P.S.:您的 Maven POM 还包含一些问题,例如运行时依赖于 AspectJ Runtime 1.8.4,但旧版本 1.5 中的 AspectJ Maven Plugin 使用 AspectJ Tools 1.7.3。当前插件版本 1.7 使用 AspectJ Tools 1.8.2,如有必要,可以通过插件依赖项配置升级到 1.8.4。

关于java - AspectJ 示例项目中出现错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28059399/

相关文章:

aop - 如何在 spring aop 中将上下文参数传递给建议

java - 注释字段x时,在构建时将注释添加到Java getter getX()

java - Spring Aspect 将不会运行

java - 禁用浏览器中的后退按钮

java - 我的涉及字符位置的 do-while 循环有问题

java - 如何在从java中的 session 中检索 session 数据时验证 session 数据?

JAVA面向切面编程-运行时切面编织和类加载时切面编织

java - 如何开发Java桌面应用程序连接蓝牙 "HC-05"?

java - 如果没有@Service @Controller,AOP 无法切入类

java - Java中如何获取抛出异常的方法名