使用jdk1.5在Eclipse中运行Maven Project时出错

时间:2013-01-17 14:08:06

标签: eclipse maven m2e jdk1.5

操作系统:Ubuntu 12.10
Eclipse:4.2
Java:jdk1.5.0_22和jdk1.7
Apache Maven:3.0.4
Maven主页:/ usr / share / maven
m2e:1.2.020120903-1050

我在Eclipse中创建了一个非常简单的“Hello,World”Maven项目,以便测试它以迁移我们自己的项目(使用1.5)。我的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>br.com.contmatic</groupId>
  <artifactId>maven-test</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <name>MavenTest</name>
  <description>teste do maven</description>
  <build>
    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <configuration>
          <source>1.5</source>
          <target>1.5</target>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>

我在项目构建路径中设置了J2SE-1.5(jdk1.5.22)。 然而,尝试从Eclipse中运行Maven Clean或Maven Install,我收到以下错误:

Exception in thread "main" java.lang.UnsupportedClassVersionError: Bad version number in .class file
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:621)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:124)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:260)
    at java.net.URLClassLoader.access$100(URLClassLoader.java:56)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:195)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
    at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClassFromSelf(ClassRealm.java:386)
    at org.codehaus.plexus.classworlds.strategy.SelfFirstStrategy.loadClass(SelfFirstStrategy.java:42)
    at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClass(ClassRealm.java:244)
    at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClass(ClassRealm.java:230)
    at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
    at org.apache.maven.cli.MavenCli.container(MavenCli.java:375)
    at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:191)
    at org.apache.maven.cli.MavenCli.main(MavenCli.java:141)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:592)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:290)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:230)
    at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409)
    at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:352)

谷歌搜索,我发现当用于编译的jre版本与用于运行的版本不同时会发生这种情况。将所有内容更改为1.7(pom.xml和构建路径)可以修复错误,这表明它可以使用java 1.7进行编译或运行。

但我似乎无法在配置中找到错误。

运行时

mvn clean install

在终端中,maven构建项目没有错误。

我在Eclipse中可能做错了什么?

1 个答案:

答案 0 :(得分:2)

原来我的一些Maven依赖项没有用1.5编译,这导致了问题。它没有在控制台中发生,因为我已经将java 1.7设置为默认值。

幸运的是,我能够使用1.7构建我的项目并指定1.5来运行编译和执行。方法如下:

在Eclipse&gt;运行&gt;运行配置&gt; Maven Build&gt; New,我有这个配置:

主要标签

基本目录:

${project_loc}

目标:

clean install

我刚刚选择了JRE选项卡并使用我的1.7 SDK安装选择了Alternate JRE。

接下来,我必须包含1.5作为maven-compiler-plugin my pom.xml的源和目标,如下所示:

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.0</version>
            <configuration>
                <encoding>ISO-8859-1</encoding>
                <source>1.5</source>
                <target>1.5</target>
            </configuration>
        </plugin>

它有效。