从 Intellij IDEA 内部构建时如何在工件 JAR 中包含 slf4j-simple
How to include slf4j-simple in the artifact JAR when build from inside Intellij IDEA
使用 Intellij IDEA(版本 2017.2.1)我有一个 Java/Maven 项目,我想在其中包含 slf4j
slf4j-binding
.
我知道 Whosebug 有大量关于 slf4j
及其缺失绑定的问题,但大多数与 Eclipse 有关。然而,我的问题出现在 Intellij 下。
在 pom.xml
我在 <dependencies>
下列出:
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.25</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-simple -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.7.25</version>
</dependency>
现在当我让 Intellij 构建一个工件 JAR 然后我从命令行 运行 JAR 我得到(可怕的)错误:
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
经检查,JAR 确实不包含 slf4j-simple
类(尽管存在 slf4j
类)。我该如何解决这个问题并指示 Intellij 将 slf4j-simple 合并到 pom.xml
?
中
为了完整起见,这里是完整项目 pom.xml
Intellij 使用:
<?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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>au.gov.acic.travelalert</groupId>
<artifactId>extract-data</artifactId>
<version>1.0-SNAPSHOT</version>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.25</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-simple -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.7.25</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-beanutils/commons-beanutils -->
<dependency>
<groupId>commons-beanutils</groupId>
<artifactId>commons-beanutils</artifactId>
<version>1.9.3</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.6</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-collections4 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-collections4</artifactId>
<version>4.1</version>
</dependency> <dependency>
<!-- jsoup HTML parser library @ https://jsoup.org/ -->
<groupId>org.jsoup</groupId>
<artifactId>jsoup</artifactId>
<version>1.10.3</version>
</dependency>
</dependencies>
</project>
最后说明: 开始时,当我设置项目时,日志记录在 IDE 中甚至不起作用 ,尽管 pom.xml
中的条目正确。但不知何故,在为 slf4j-log4j12
添加(并随后删除)依赖项之后,IDE 选择了 slf4j-simple
,但在写出人工制品 JAR 时仍未将其捆绑。 ..
你可以试试这个解决方案;转到 home
目录并删除 .m2
目录(隐藏)更新 maven 项目并尝试重建。如果您使用的是(Indigo、Juno 和 Kepler)版本的 Eclipse,请检查您的 Eclipse 版本,如果您想在其中工作,请升级最新版本或 stil,然后您可以参考以下内容;这个 Whosebug link 在这个问题上有最可靠的答案:
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder". error Konstantinos Margaritis
的问题和许多 java 专家的回答。
执行 mvn dependency:tree 并检查:
- slf4j-api 和 slf4j-simple 必须存在。
- 不应存在其他 slf4j 绑定库
- 可以存在 slf4j 桥(那些在库名称上以“-slf4j”后缀结尾的桥;例如,log4j-over-slf4j)。
- 确保所有 slf4j 库版本匹配
- 确保没有不同版本的重复 slf4j 库。
如果一切正常,slf4j-api 没有理由出现在工件上,但没有 slf4j-simple。你打包jar干什么?
问题是 IntelliJ 的 XML JAR 工件配置不包含 slf4j-simple
库。
这说明IntelliJ找到了lib ray(maven根据`POM/XML~下载的)用于项目内部执行,但并没有打包到JAR中。
解决方案是将库添加到 XML 配置中,或者
- 手动,通过编辑 XML 文件。 (您可以在
[projectroot].idea/artifacts/[projectname_jar.xml
下找到它)
或
- 通过 IntelliJ 的 GUI,打开 Artifacts 对话框(文件 --> 项目结构 --> Artifacts)然后添加Libra 到 输出布局 列表。
使用 Intellij IDEA(版本 2017.2.1)我有一个 Java/Maven 项目,我想在其中包含 slf4j
slf4j-binding
.
我知道 Whosebug 有大量关于 slf4j
及其缺失绑定的问题,但大多数与 Eclipse 有关。然而,我的问题出现在 Intellij 下。
在 pom.xml
我在 <dependencies>
下列出:
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.25</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-simple -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.7.25</version>
</dependency>
现在当我让 Intellij 构建一个工件 JAR 然后我从命令行 运行 JAR 我得到(可怕的)错误:
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
经检查,JAR 确实不包含 slf4j-simple
类(尽管存在 slf4j
类)。我该如何解决这个问题并指示 Intellij 将 slf4j-simple 合并到 pom.xml
?
为了完整起见,这里是完整项目 pom.xml
Intellij 使用:
<?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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>au.gov.acic.travelalert</groupId>
<artifactId>extract-data</artifactId>
<version>1.0-SNAPSHOT</version>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.25</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-simple -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.7.25</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-beanutils/commons-beanutils -->
<dependency>
<groupId>commons-beanutils</groupId>
<artifactId>commons-beanutils</artifactId>
<version>1.9.3</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.6</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-collections4 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-collections4</artifactId>
<version>4.1</version>
</dependency> <dependency>
<!-- jsoup HTML parser library @ https://jsoup.org/ -->
<groupId>org.jsoup</groupId>
<artifactId>jsoup</artifactId>
<version>1.10.3</version>
</dependency>
</dependencies>
</project>
最后说明: 开始时,当我设置项目时,日志记录在 IDE 中甚至不起作用 ,尽管 pom.xml
中的条目正确。但不知何故,在为 slf4j-log4j12
添加(并随后删除)依赖项之后,IDE 选择了 slf4j-simple
,但在写出人工制品 JAR 时仍未将其捆绑。 ..
你可以试试这个解决方案;转到 home
目录并删除 .m2
目录(隐藏)更新 maven 项目并尝试重建。如果您使用的是(Indigo、Juno 和 Kepler)版本的 Eclipse,请检查您的 Eclipse 版本,如果您想在其中工作,请升级最新版本或 stil,然后您可以参考以下内容;这个 Whosebug link 在这个问题上有最可靠的答案:
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder". error Konstantinos Margaritis
的问题和许多 java 专家的回答。
执行 mvn dependency:tree 并检查:
- slf4j-api 和 slf4j-simple 必须存在。
- 不应存在其他 slf4j 绑定库
- 可以存在 slf4j 桥(那些在库名称上以“-slf4j”后缀结尾的桥;例如,log4j-over-slf4j)。
- 确保所有 slf4j 库版本匹配
- 确保没有不同版本的重复 slf4j 库。
如果一切正常,slf4j-api 没有理由出现在工件上,但没有 slf4j-simple。你打包jar干什么?
问题是 IntelliJ 的 XML JAR 工件配置不包含 slf4j-simple
库。
这说明IntelliJ找到了lib ray(maven根据`POM/XML~下载的)用于项目内部执行,但并没有打包到JAR中。
解决方案是将库添加到 XML 配置中,或者
- 手动,通过编辑 XML 文件。 (您可以在
[projectroot].idea/artifacts/[projectname_jar.xml
下找到它)
或
- 通过 IntelliJ 的 GUI,打开 Artifacts 对话框(文件 --> 项目结构 --> Artifacts)然后添加Libra 到 输出布局 列表。