Почему jdk 1.5 не может загрузить банку, созданную с помощью maven?(Неверный номер версии) - PullRequest
0 голосов
/ 18 августа 2010

Я использую Solaris, я создал приложение maven на jdk 1.6, но с помощью maven-compiler-plugin, чтобы указать цель как 1.5.Вот фрагмент моего pom.xml:

  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <configuration>
      <source>1.5</source>
      <target>1.5</target>
    </configuration>
  </plugin>

Хотя, когда я пытаюсь запустить в окне соляриса, я получаю:

bash-2.05$ ./merchantInfoUpdate.sh 
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:620)
        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 java.lang.ClassLoader.loadClass(ClassLoader.java:306)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:268)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:251)
        at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)

И если я запускаю mvn install -X (с отладкой) и плагин компилятора говорит мне:

[DEBUG] Configuring mojo 'org.apache.maven.plugins:maven-compiler-plugin:2.0.2:compile' -->
[DEBUG]   (f) basedir = /home/emerson/newworkspace/java-batch-updater
[DEBUG]   (f) buildDirectory = /home/emerson/newworkspace/java-batch-updater/target
[DEBUG]   (f) classpathElements = [/home/emerson/newworkspace/java-batch-updater/target/classes, /home/emerson/.m2/repository/commons-logging/commons-logging/1.1.1/commons-logging-1.1.1.jar, /home/emerson/.m2/repository/log4j/log4j/1.2.12/log4j-1.2.12.jar]
[DEBUG]   (f) compileSourceRoots = [/home/emerson/newworkspace/java-batch-updater/src/main/java]
[DEBUG]   (f) compilerId = javac
[DEBUG]   (f) debug = true
[DEBUG]   (f) failOnError = true
[DEBUG]   (f) fork = false
[DEBUG]   (f) optimize = false
[DEBUG]   (f) outputDirectory = /home/emerson/newworkspace/java-batch-updater/target/classes
[DEBUG]   (f) outputFileName = com.company.ingestion.updater-2010.01
[DEBUG]   (f) projectArtifact = com.yell:com.company.ingestion.updater:jar:2010.01
[DEBUG]   (f) showDeprecation = false
[DEBUG]   (f) showWarnings = false
[DEBUG]   (f) source = 1.5
[DEBUG]   (f) staleMillis = 0
[DEBUG]   (f) target = 1.5
[DEBUG]   (f) verbose = false

emerson@emerson-desktop:~/newworkspace/java-batch-updater/target/expand$ file com/yell/ingestion/updater/ListingsManager.class

com/yell/ingestion/updater/ListingsManager.class: compiled Java class data, version 50.0 (Java 1.6)

Java-версия:

bash-2.05$ java -version
java version "1.5.0_05"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_05-b05)
Java HotSpot(TM) Server VM (build 1.5.0_05-b05, mixed mode)

Запустить содержимое скрипта:

bash-2.05$ more merchantInfoUpdate.sh 
LIB=lib

   CLASSPATH="."
   for i in `find $LIB  -name *.jar`; do CLASSPATH="$CLASSPATH:$i"; done;
    export CLASSPATH
   CLASSPATH=$CLASSPATH:resources/properties
java  $* -cp $CLASSPATH com.company.ingestion.updater.ListingsManager 

Я убедился, что это действительнобанку, которую я создаю, которая вызывает проблему, оставляя ее в покое в classpath приложения, и все равно я получаю ту же ошибку.

Есть идеи?

Спасибо

Ответы [ 2 ]

1 голос
/ 19 августа 2010

Вы абсолютно уверены, что используете Java 1.5 на коробке Solaris, а не 1.4? Каков вывод Java-версии там? Что содержит merchantInfoUpdate.sh? Помещает ли он какой-либо другой JAR-файл библиотеки в путь к классам, который может быть скомпилирован с использованием формата файла класса Java 1.6?

0 голосов
/ 19 августа 2010

Кажется, что каким-то образом maven пришел к выводу, что классы не нужно компилировать. · Я перезапустил установку с чистой версией, и на этот раз я увидел правильную версию:

чистая установка mvn

, а затем ..

file /home/emerson/newworkspace/java-batch-updater/target/classes/com/company/ingestion/updater/ListingsManager.class /home/emerson/newworkspace/java-batch-updater/target/classes/com/company/ingestion/updater/ListingsManager.class: скомпилированные данные класса Java, версия 49.0 (Java 1.5)

Спасибо всем за помощь!

Эмерсон

...