使用dev.aspectj:aspectj-maven-plugin:1.14
插件代替org.codehaus.mojo:aspectj-maven-plugin:1.15.0
来执行编译时织入。org.codehaus.mojo:aspectj-maven-plugin
是Apache Maven官方提供的插件,我们在网上找到关于aspectj-maven-plugin插件的介绍都是基于这个插件的。dev.aspectj:aspectj-maven-plugin
是eclipse aspectj项目官方提供的插件,
我不太清楚为什么有两个官方插件。但是dev.aspectj:aspectj-maven-plugin
从1.13
版本开始为解决module无法解析问题,增加了<javaModules></javaModules>
参数,用于定义ajc
的 --module-path
参数,说明如下图:
参见 https://dev-aspectj.github.io/aspectj-maven-plugin/compile-mojo.html#javaModules
根据这个参数,我修改了pom.xml,使用dev.aspectj:aspectj-maven-plugin:1.14
插件代替org.codehaus.mojo:aspectj-maven-plugin:1.15.0
,并增加了<javaModules></javaModules>
参数定义如下:
<project>
<properties>
<maven.compiler.source>9</maven.compiler.source>
<maven.compiler.target>9</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<com4j.version>4.0.0</com4j.version>
<aocache.version>0.4.5</aocache.version>
<aspectj.version>1.9.21</aspectj.version>
</properties>
<build>
<plugins>
<plugin>
<groupId>dev.aspectj</groupId>
<version>1.14</version>
<artifactId>aspectj-maven-plugin</artifactId>
<configuration>
<encoding>UTF-8</encoding>
<complianceLevel>9</complianceLevel>
<verbose>true</verbose>
<showWeaveInfo>true</showWeaveInfo>
<!-- 忽略adviceDidNotMatch警告-->
<Xlint>adviceDidNotMatch=ignore</Xlint>
<aspectLibraries>
<aspectLibrary>
<groupId>com.gitee.l0km</groupId>
<artifactId>aocache</artifactId>
</aspectLibrary>
</aspectLibraries>
<javaModules>
<javaModule>
<groupId>com.gitee.l0km</groupId>
<artifactId>com4j-base</artifactId>
</javaModule>
<javaModule>
<groupId>com.gitee.l0km</groupId>
<artifactId>com4j-base2</artifactId>
</javaModule>
<javaModule>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
</javaModule>
<javaModule>
<groupId>com.gitee.l0km</groupId>
<artifactId>aocache</artifactId>
</javaModule>
</javaModules>
</configuration>
<executions>
<execution>
<goals>
<goal>compile</goal>
</goals>
</execution>
</executions>
<dependencies>
<!-- 确保编译器使用的aspectj工具版本与依赖项使用的版本相同。避免警告 -->
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjtools</artifactId>
<version>${aspectj.version}</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
</project>
修改后效果立竿见影,aspectj-maven-plugin
的报错减少了,只剩下aocache
这个模块找不到。
[INFO] --- aspectj-maven-plugin:1.14:compile (default) @ javadocreader9 ---
[INFO] Showing AJC message detail for messages of types: [error, warning, fail]
[ERROR] aocache cannot be resolved to a module
J:\javadocreader9\src\main\java\module-info.java:8
requires aocache;
^^^^^^^
关于aocache
这个模块为什么找不到,我至今也没想明白原因,aocache
这个模块也是我写的(仓库地址https://gitee.com/l0km/aocache)。除了项目使用org.apache.maven.plugins:maven-shade-plugin
插件打包之外,它与同样是我写的模块com4j.base
,com4j-base2
(仓库地址https://gitee.com/l0km/common-java)相比没有什么特别的。我尝试了很多方式改进aocache
但就是无法解决这个问题。问题只能留待以后了。