我有一个多模块的项目。这个方面目前被添加到“核心”项目中。在这里执行mvn clean install
时,它可以正常工作。但是,尝试在父项目上执行mvn clean install
时会失败,并在编译其他项目之一时出现以下错误:
无法解析类型org.hibernate.annotations.CacheConcurrencyStrategy
。它是从所需的.class文件间接引用的
如果我在该项目中添加Hibernate核心依赖项,它也可以工作,但是将依赖项添加到不应该有依赖项的项目中是没有意义的-所以它不是一个解决方案。当使用javac
编译时,它工作得很好。
原因何在?我如何修复它,以便可以使用AspectJ编译器,而不会泄漏对不应该具有依赖关系的项目?
我在父POM中有以下配置:
<build>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>aspectj-maven-plugin</artifactId>
<version>1.5</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
<complianceLevel>1.6</complianceLevel>
</configuration>
<executions>
<execution>
<goals>
<goal>compile</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
更新
我刚发现。每次运行mvn clean install
都会失败。但是,运行一次mvn [clean] install
会失败。然后在不使用clean
的情况下运行mvn install
。我看到目标文件夹中的builddef.lst
是它工作和失败的原因,这取决于您是否干净地运行。所以现在我的问题是:如何自动生成此文件?
父POM-文件:
<?xml version="1.0" encoding="UTF-8"?>
<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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.mycompany</groupId>
<artifactId>core-lib</artifactId>
<name>core-lib</name>
<packaging>pom</packaging>
<build>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>aspectj-maven-plugin</artifactId>
<version>1.5</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
<complianceLevel>1.6</complianceLevel>
</configuration>
<executions>
<execution>
<goals>
<goal>compile</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>1.7.4</version>
</dependency>
</dependencies>
<modules>
<module>core-xyz</module>
<module>core-xyz2</module>
</modules>
</project>
发布于 2014-06-17 03:54:00
在maven调用上启用debug以深入挖掘。您应该注意到,aspectj编译器仅在第一次使用clean调用maven时被调用。由于builddef.lst在第一次调用后就已经存在,所以在不使用clean的情况下调用会跳过aspectj编译。
这个aspectj编译插件的行为之前已经被观察到了,并在这里进行了描述:
http://out-println.blogspot.com/2007/08/compile-time-checks-with-aspectj-part-2.html?m=1
您需要更深入地研究以解决底层问题,但正如一位评论者已经建议的那样,aspectj编译器应该只在需要它的模块中启用。
否则,正如您已经观察到的,aspectj编译需要额外的依赖项。我已经将aspectj编译合并到我自己的工作中,只将它限制在需要它的模块中,而没有问题。
发布于 2014-06-18 14:53:39
根据AspectJ compiler Maven plugin,您可以设置argumentFileName
来定位现有的builddef.lst
。
因此,您可以生成builddef.lst
并将其复制到您的资源文件夹,并指示AspectJ Maven插件使用该文件。
https://stackoverflow.com/questions/24206634
复制相似问题