以下是我的pom.xml的主要部分:
属性:
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.build.targetEncoding>UTF-8</project.build.targetEncoding>
<jdk.release>10</jdk.release>
<jdk.vendor>oracle</jdk.vendor>
<maven.compiler.source>1.10</maven.compiler.source>
<maven.compiler.target>1.10</maven.compiler.target>
<dependency.asm.version>6.2</dependency.asm.version>
<dependency.log4j2.version>2.11.0</dependency.log4j2.version>
<plugin.maven-toolchains.version>1.1</plugin.maven-toolchains.version>
<plugin.maven-compiler.version>3.7.0</plugin.maven-compiler.version>
<plugin.maven-dependency.version>3.1.1</plugin.maven-dependency.version>
<plugin.maven-jar.version>3.1.0</plugin.maven-jar.version>
</properties>
依赖关系:
<dependencies>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${dependency.log4j2.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${dependency.log4j2.version}</version>
</dependency>
</dependencies>
插件:
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-toolchains-plugin</artifactId>
<version>${plugin.maven-toolchains.version}</version>
<executions>
<execution>
<goals>
<goal>toolchain</goal>
</goals>
</execution>
</executions>
<configuration>
<toolchains>
<jdk>
<version>${jdk.release}</version>
<vendor>${jdk.vendor}</vendor>
</jdk>
</toolchains>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>${plugin.maven-compiler.version}</version>
<configuration>
<source>${maven.compiler.source}</source>
<target>${maven.compiler.target}</target>
<release>${jdk.release}</release>
</configuration>
<dependencies>
<dependency>
<groupId>org.ow2.asm</groupId>
<artifactId>asm</artifactId>
<version>${dependency.asm.version}</version>
</dependency>
</dependencies>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>${plugin.maven-dependency.version}</version>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<outputDirectory>${project.basedir}/dist/lib/</outputDirectory>
</configuration>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>${plugin.maven-jar.version}</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>./lib/</classpathPrefix>
<mainClass>com.mycompany.tbe.myproject.Application</mainClass>
<addDefaultImplementationEntries>true</addDefaultImplementationEntries>
<addDefaultSpecificationEntries>true</addDefaultSpecificationEntries>
</manifest>
</archive>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
<outputDirectory>${project.basedir}/dist</outputDirectory>
</configuration>
</plugin>
</plugins>
项目结构是:
project
+
|-- src
| +
| |-- main
| | +
| | |-- java
| | | +
| | | |-- com
| | | | +
| | | | |-- mycompany
| | | | | +
| | | | | |-- tbe
| | | | | | +
| | | | | | |-- myproject
| | | |-- module-info.java
| | |-- resources
|-- pom.xml
module-info.java
包含:
/**
* @author Tapas Bose
*/
module project {
exports com.mycompany.tbe.myproject;
requires log4j.api;
}
当我执行:mvn clean package
时,它会抛出错误,告诉:
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.7.0:compile (default-compile) on project <my-project>: Compilation failure
[ERROR] <path-to-my-project>/src/main/java/module-info.java:[7,15] error: module not found: log4j.api
我还尝试通过指定配置向--add-modules
提供maven-compiler-plugin
参数:
<configuration>
<compilerArgs>
<arg>--add-modules</arg>
<arg>log4j.api</arg>
</compilerArgs>
</configuration>
但那也不起作用。
几点:
如果我删除module-info.java
,则可以。
module-info.java
由Eclipse生成。
java describe-module
揭示了以下内容:
$ jar --file=log4j-api-2.11.0.jar --describe-module
releases: 9
No root module descriptor, specify --release
$ jar --file=log4j-api-2.11.0.jar --describe-module --release 9
releases: 9
org.apache.logging.log4j jar:file:///<path-to-maven-local-repository>/org/apache/logging/log4j/log4j-api/2.11.0/log4j-api-2.11.0.jar/!META-INF/versions/9/module-info.class
exports org.apache.logging.log4j
exports org.apache.logging.log4j.message
exports org.apache.logging.log4j.simple
exports org.apache.logging.log4j.spi
exports org.apache.logging.log4j.status
exports org.apache.logging.log4j.util
requires java.base mandated
uses org.apache.logging.log4j.message.ThreadDumpMessage$ThreadInfoFactory
uses org.apache.logging.log4j.spi.Provider
uses org.apache.logging.log4j.util.PropertySource
因此,如果将module-info.java
更改为:
/**
* @author Tapas Bose
*/
module project {
exports com.mycompany.tbe.myproject;
requires org.apache.logging.log4j;
}
Eclipse Java Editor开始在文件module-info.java
中显示编译错误:
此外,在使用log4j-api软件包的其他Java类中:
但mvn clean package
在这种情况下适用于警告信息:
[WARNING] ********************************************************************************************************************
[WARNING] * Required filename-based automodules detected. Please don't publish this project to a public artifact repository! *
[WARNING] ********************************************************************************************************************
我正在使用:
在另一个SO线程中:Spring Boot module not found error要求它清理maven的本地存储库。我也尝试使用mvn clean dependency:purge-local-repository package
做同样的事,但没有运气。
答案 0 :(得分:2)
问题是log4j-api-2.11.0.jar是一个多版本jar,在META-INF / versions / 9 / module-info.class中有一个module-info.class,eclipse没有&#39; t支持,请参阅https://bugs.eclipse.org/bugs/show_bug.cgi?id=534624
答案 1 :(得分:1)
我能够以某种方式完成这项工作。我正在使用JDK 10.0.1
const str = "data>/ab/cd/peter} ;gopal came prop>/site/sing/perl};";
const rex = />[^}]+}/g;
let match;
while (!!(match = rex.exec(str))) {
console.log(match[0]);
}
更改为以下几行:
module-info.java
我正在使用log4j的2.11.1版本。requires log4j.api;
requires org.apache.logging.log4j.core;
的导入内容更改为不使用通配符。因此他们更改为:import org.apache.logging.log4j.*;
就这样,它可以与Maven和Eclipse一起使用。