4

当我从命令行(使用 far managerR)运行“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>
4

6 回答 6

2

这有时会发生在 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项目”
于 2013-02-17T11:44:47.043 回答
1

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

于 2013-02-16T15:47:08.207 回答
0

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

这是我的解决方案:

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

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

于 2013-07-13T22:18:31.030 回答
0

使用 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

于 2013-12-06T07:34:21.710 回答
0

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

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

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

3)在恐慌之前用你自己的Maven检查控制台中的所有内容。例如我的命令 mvn site mvn install mvn tomcat:redeploy

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

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

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

于 2013-02-17T10:43:23.473 回答
0

在 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。

于 2016-02-21T15:13:01.223 回答