【问题标题】:m2eclipse compilation failurem2eclipse 编译失败
【发布时间】:2013-02-01 06:05:27
【问题描述】:

当我从命令行(使用 far manageR)运行“mvn site”时,一切正常,它将所有必要的 jar 下载到存储库并执行任务。

但是当我尝试使用 m2eclipse 插件从 eclipse 做同样的事情(mvn 站点)时,它会告诉我:

[INFO] Scanning for projects...
[INFO]                                                                         
[INFO] ------------------------------------------------------------------------
[INFO] Building jdbc_maven 0.0.1-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO] 
[INFO] --- maven-resources-plugin:2.5:resources (default-resources) @ jdbc_maven ---
[debug] execute contextualize
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 1 resource
[INFO] 
[INFO] --- maven-compiler-plugin:3.0:compile (default-compile) @ jdbc_maven ---
[INFO] Changes detected - recompiling the module!
[INFO] Compiling 7 source files to G:\workspace\jdbc_maven\target\classes
[INFO] -------------------------------------------------------------
[ERROR] COMPILATION ERROR : 
[INFO] -------------------------------------------------------------
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcRoleDao.java:[8,23] error: package org.apache.log4j does not exist
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcRoleDao.java:[13,16] error: cannot find symbol
[ERROR]   symbol:   class Logger
  location: class JdbcRoleDao
G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\User.java:[5,23] error: package org.apache.log4j does not exist
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\User.java:[28,16] error: cannot find symbol
[ERROR]   symbol:   class Logger
  location: class User
G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcUserDao.java:[13,23] error: package org.apache.log4j does not exist
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcUserDao.java:[19,16] error: cannot find symbol
[ERROR]   symbol:   class Logger
  location: class JdbcUserDao
G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcRoleDao.java:[13,29] error: cannot find symbol
[ERROR]   symbol:   variable Logger
  location: class JdbcRoleDao
G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\User.java:[28,29] error: cannot find symbol
[ERROR]   symbol:   variable Logger
  location: class User
G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcUserDao.java:[19,29] error: cannot find symbol
[INFO] 9 errors 
[INFO] -------------------------------------------------------------
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1.387s
[INFO] Finished at: Sat Feb 16 11:05:13 EET 2013
[INFO] Final Memory: 7M/154M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.0:compile (default-compile) on project jdbc_maven: Compilation failure: Compilation failure:
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcRoleDao.java:[8,23] error: package org.apache.log4j does not exist
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcRoleDao.java:[13,16] error: cannot find symbol
[ERROR] symbol:   class Logger
[ERROR] location: class JdbcRoleDao
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\User.java:[5,23] error: package org.apache.log4j does not exist
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\User.java:[28,16] error: cannot find symbol
[ERROR] symbol:   class Logger
[ERROR] location: class User
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcUserDao.java:[13,23] error: package org.apache.log4j does not exist
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcUserDao.java:[19,16] error: cannot find symbol
[ERROR] symbol:   class Logger
[ERROR] location: class JdbcUserDao
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcRoleDao.java:[13,29] error: cannot find symbol
[ERROR] symbol:   variable Logger
[ERROR] location: class JdbcRoleDao
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\User.java:[28,29] error: cannot find symbol
[ERROR] symbol:   variable Logger
[ERROR] location: class User
[ERROR] G:\workspace\jdbc_maven\src\main\java\com\nixsolutions\JdbcUserDao.java:[19,29] error: cannot find symbol

这是我的 pom.xml

<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>jdbc_maven</groupId>
    <artifactId>jdbc_maven</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>jdbc_maven</name>
    <url>http://maven.apache.org</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    </properties>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.8.1</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.dbunit</groupId>
            <artifactId>dbunit</artifactId>
            <version>2.4.8</version>
        </dependency>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-simple</artifactId>
            <version>1.6.4</version>
        </dependency>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.6.4</version>
        </dependency>

        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>1.3.169</version>
        </dependency>

        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
            <exclusions>
                <exclusion>
                    <groupId>javax.jms</groupId>
                    <artifactId>jms</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>com.sun.jmx</groupId>
                    <artifactId>jmxri</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>com.sun.jdmk</groupId>
                    <artifactId>jmxtools</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

    </dependencies>

    <build>
        <plugins>

            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-site-plugin</artifactId>
                <version>3.0</version>
                <configuration>
                    <reportPlugins>
                        <plugin> 
                            <groupId>org.apache.maven.plugins</groupId> 
                            <artifactId>maven-surefire-report-plugin</artifactId> 
                            <version>2.8</version> 
                        </plugin> 
                        <plugin> 
                            <groupId>org.apache.maven.plugins</groupId> 
                            <artifactId>maven-checkstyle-plugin</artifactId> 
                            <version>2.6</version> 
                            <configuration> 
                                <configLocation>sun_checks.xml</configLocation> 
                            </configuration> 
                        </plugin> 
                        <plugin> 
                            <groupId>org.apache.maven.plugins</groupId> 
                            <artifactId>maven-javadoc-plugin</artifactId> 
                            <version>2.6.1</version> 
                        </plugin> 
                    </reportPlugins>
                </configuration>
            </plugin>


            <!-- JDK 1.7 COMPILER - DON'T TOUCH -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.0</version>
                <configuration>
                    <source>1.7</source>
                    <target>1.7</target>
                    <showDeprecation>true</showDeprecation>
                    <showWarnings>true</showWarnings> 
                    <executable>${env.JAVA_HOME}/bin/javac</executable>
                    <fork>true</fork> 
                </configuration>
            </plugin>
            <!-- JDK 1.7 COMPILER - DON'T TOUCH -->

        </plugins>
    </build>

</project>

【问题讨论】:

    标签: maven maven-2 m2eclipse


    【解决方案1】:

    在eclipse中做项目->清理(也尝试刷新项目)。当您从命令行编译代码时,有时会在 eclipse 中引起一些问题,并且必须在 eclipse 中重新编译代码

    【讨论】:

      【解决方案2】:

      每个使用 m2eclipse 插件并苦苦挣扎的人,这里是我的提示:

      1) 使用你自己的 maven,而不是在 m2eclipse 中构建,你可以在 m2eclipse 首选项中切换到它

      2) 从愚蠢的 C:\Users\current_user-m2\repository 更改存储库位置 到 D:\repository 或任何其他没有 ~ 或任何其他特殊升的正常路径

      3) 在恐慌之前使用您自己的 Maven 检查控制台中的所有内容。例如我的命令像 mvn网站 mvn 安装 mvn tomcat:重新部署

      从控制台工作出色,但在 Eclipse 内部失败。这意味着 m2eclipse 参数是错误的,您应该设置自己的参数。

      4)不要依赖上下文命令(右键单击-运行为-maven测试/站点/构建) 在运行中创建自己的命令 - maven build - 在菜单中选择正确的 JRE 版本(在我的例子中是 1.7)并添加任何其他参数不要忘记给这个命令命名,例如:“maven tomcat:redeploy JDK 7” - 这会给你一个很好的机会来运行你想要的任何东西,并且不会面临 90% 的 m2eclipse 问题和错误。

      附:我在 maven 2 和 m2eclipse 上苦苦挣扎了 20 多个小时。希望我的提示对某些人有用。

      【讨论】:

        【解决方案3】:

        这有时会发生在 m2eclipse 中,这是因为当您向 pom.xml 添加新的依赖项时,m2e 会自动将其添加到类路径中,而这个类路径生成存在一些问题。

        一个快速而肮脏的解决方法是

        • Remove the project from the eclipse
        • 现在navigate to the project folderdelete .settings directory and .classpath file
        • Import the project into the eclipse 作为“Maven 项目”

        【讨论】:

        • 同时删除.project文件
        【解决方案4】:

        我遇到了同样的问题,我想我已经找到了解决方案。问题是在运行配置下,您项目的 maven 配置没有刷新整体配置中的新设置。

        这是我的解决方案:

        1. 在运行按钮(带有绿色三角形的那个)中,选择运行配置
        2. 进入“maven build”类别并查找您的项目之一
        3. 检查 maven 运行时、JRE 和类似的配置是否正确:在 eclipse 中更改时不会刷新这些值
        4. 应用更改并运行

        这个解决方案对我有用(我一直在使用 value maven 运行时,在嵌入式和外部之间切换,这似乎是问题所在。

        【讨论】:

          【解决方案5】:

          使用 m2eclipse 生成文档时出现同样的问题,目标 javadoc:javadoc 或 javadoc:jar,同时 Project -> Generate Javadoc 工作正常。在第一种情况下,错误的类路径似乎有问题。
          解决方法:

          1.run Project -> Generate Javadoc with check option "Save the settings of the Javadoc export as an antscript"
          2.将生成javadoc.xml
          3.运行m2eclipse,javadoc.sh失败后,options,packages会在/site/apidocs/
          4. 从 javadoc.xml 中获取类路径的内容并将类路径放入选项文件中
          5. 运行./javadoc.sh

          【讨论】:

            【解决方案6】:

            在 pom.xml 中确保您在编译时具有 log4j 范围

            <dependency>
                <groupId>org.apache.logging.log4j</groupId>
                <artifactId>log4j-api</artifactId>
                <version>2.5</version>
                <scope>compile</scope>
            </dependency>
            
            <dependency>
                <groupId>org.apache.logging.log4j</groupId>
                <artifactId>log4j-web</artifactId>
                <version>2.5</version>
                <scope>compile</scope>
            </dependency>
            

            它仍然将 log4j.jars 放入 .war。

            【讨论】:

              猜你喜欢
              • 2021-10-07
              • 2021-06-14
              • 2021-01-29
              • 2018-11-06
              • 1970-01-01
              • 2016-08-16
              • 2015-09-07
              • 2019-08-06
              • 2013-07-03
              相关资源
              最近更新 更多