错误:从cmd运行代码时,包org.apache.log4j不存在

时间:2019-06-27 09:14:36

标签: java maven cmd log4j

运行javac Main.java命令时,出现package org.apache.log4j does not exist错误。

Main

public class Main {

    private static Logger logger = Logger.getLogger(Main.class);

    public static void main(String[] args) {
        BasicConfigurator.configure();

        logger.info("in Main class");
    }
}

pom.xml

<?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>groupId</groupId>
    <artifactId>example</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
            <scope>compile</scope>
        </dependency>
    </dependencies>
</project>

log4j.properties

log4j.rootCategory=debug,console
log4j.logger.com.demo.package=debug,console
log4j.additivity.com.demo.package=false

log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.target=System.out
log4j.appender.console.immediateFlush=true
log4j.appender.console.encoding=UTF-8

log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.conversionPattern=%d [%t] %-5p %c - %m%n

我收到的错误消息是:

enter image description here

1 个答案:

答案 0 :(得分:0)

假设1(错误):源类中没有张贴过的任何进口→必须添加进口

看起来您在import类中缺少Main条语句。 试试这个:

import org.apache.log4j.BasicConfigurator;
import org.apache.log4j.Logger;

public class Main {

    private static Logger logger = Logger.getLogger(Main.class);

    public static void main(String[] args) {
        BasicConfigurator.configure();

        logger.info("in Main class");
    }
} 

实际问题(我固定了帖子中的图片显示后)

您不是通过命令行javac使用maven buth运行编译的。没有maven,您不会自动将依赖项添加到类路径中。

如果要从命令行运行

在这种情况下,您必须将log4j添加到类路径中。 它看起来像这样(从默认Maven布局中的<project_root>\src\main\java的sources目录运行:

javac company/Main.java -cp %userprofile%\.m2\repository\log4j\log4j\1.2.17\log4j-1.2.17.jar

我假设您的本地Maven存储库位于默认Windows路径%userprofile%\.m2中。如果在其他部分(或Linux)中,则必须将路径更改为log4j-1.2.17.jar

在这种情况下,类Main.class将被编译到与Main.class相同的包中。

如果要使用Maven进行编译

只需从mvn compile所在的目录运行pom.xml。 请注意,maven会将类编译到target目录中,即,您编译的类将位于\target\classes\company\Main.class之类的路径中(相对于您的pom.xml所在的项目根目录)。