2014-05-06 12 views
24

Próbowałem przejść na Javę 8. Podczas uruchamiania naszego serwera tomcat7, z plikiem .war skompilowanym w języku Java 7, dostaję tajemniczy błąd poniżej.org.apache.tomcat.util.bcel.classfile.ClassFormatException: Niepoprawny znacznik bajtu w stałej puli: 15 - Tomcat 7, niekompatybilność JDK?

Czy powinienem oczekiwać, że to zadziała? Ten post mówi, że tomcat 7 powinien działać z wersją 1.6 i wyższą. Nie mogę powiedzieć, czy to Tomcat jest winien, czy też .war. Przełączanie się różne wersje Java uzyskać:

  • zainstalowane JDK 7.45 - prace (samą wersję używaną do kompilowania .war)
  • JDK 7,55 zainstalowany - nie powiedzie się, jak poniżej
  • JDK 8.05 zainstalowany - nie jak poniżej

Czy kocur jest winny, czy też .war?

Caused by: org.apache.tomcat.util.bcel.classfile.ClassFormatException: Invalid byte tag in constant pool: 15 
     at org.apache.tomcat.util.bcel.classfile.Constant.readConstant(Constant.java:131) 
     at org.apache.tomcat.util.bcel.classfile.ConstantPool.<init>(ConstantPool.java:60) 
     at org.apache.tomcat.util.bcel.classfile.ClassParser.readConstantPool(ClassParser.java:209) 
     at org.apache.tomcat.util.bcel.classfile.ClassParser.parse(ClassParser.java:119) 
     at org.apache.catalina.startup.ContextConfig.processAnnotationsStream(ContextConfig.java:2032) 
     at org.apache.catalina.startup.ContextConfig.processAnnotationsJar(ContextConfig.java:1923) 
     at org.apache.catalina.startup.ContextConfig.processAnnotationsUrl(ContextConfig.java:1891) 
     at org.apache.catalina.startup.ContextConfig.processAnnotations(ContextConfig.java:1877) 
     at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1270) 
     at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:855) 
     at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:345) 
     at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119) 
     at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90) 
     at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5161) 
     at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 

Odpowiedz

0

Ja również stanąłem w obliczu tego problemu. Postępowałem zgodnie z tym błędem i musiałem uaktualnić do najnowszej wersji naszą zależność od maven na słoik ICU4J.

a błąd jest już teraz:

<dependency> 
    <groupId>com.ibm.icu</groupId> 
    <artifactId>icu4j</artifactId> 
    <version>56.1</version> 
    </dependency> 
0

miałem Java 8 na moim komputerze, ale chciałem metę mój Tomcat przy użyciu Java 7.

Następujące rozwiązanie zadziałało dla mnie.

W %CATALINA_HOME%\bin\ (Np: C: \ Tomcat \ bin) dodać setenv.bat o następującej treści:

@echo off 
set JAVA_HOME=C:\Program Files\Java\jdk1.7.0_03 
set JRE_HOME=%JAVA_HOME%\jre 
exit /B 0 

Po uruchomieniu startup.bat następujące połączenia zdarzyć:

startup.bat 
    | 
    └── catalina.bat 
       | 
       └── setenv.bat 
  • patrz:

    if not exist "%CATALINA_BASE%\bin\setenv.bat" goto checkSetenvHome 
    call "%CATALINA_BASE%\bin\setenv.bat"