欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Eclipse启动Tomcat报错: Bad version number in .class file

程序员文章站 2022-03-02 18:33:55
...

问题现象

 

在Eclipse中启动Tomcat 6运行一个JavaWeb应用,但是Tomcat启动中报异常并且启动中止,异常信息如下:

致命的: Null component Catalina:type=JspMonitor,name=jsp,WebModule=//localhost/cfJavaEEPlay,J2EEApplication=none,J2EEServer=none
java.lang.reflect.InvocationTargetException
	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:585)
	at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
	at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
Caused by: java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class cn.chenfeng.Listener.MySessionListener)
	at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2737)
	at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1124)
	at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1612)
	at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1491)
	at org.apache.catalina.startup.WebAnnotationSet.loadClassAnnotation(WebAnnotationSet.java:145)
	at org.apache.catalina.startup.WebAnnotationSet.loadApplicationListenerAnnotations(WebAnnotationSet.java:73)
	at org.apache.catalina.startup.WebAnnotationSet.loadApplicationAnnotations(WebAnnotationSet.java:56)
	at org.apache.catalina.startup.ContextConfig.applicationAnnotationsConfig(ContextConfig.java:297)
	at org.apache.catalina.startup.ContextConfig.start(ContextConfig.java:1078)
	at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:261)
	at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
	at org.apache.catalina.core.StandardContext.start(StandardContext.java:4540)
	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
	at org.apache.catalina.core.StandardHost.start(StandardHost.java:785)
	at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
	at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:445)
	at org.apache.catalina.core.StandardService.start(StandardService.java:519)
	at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
	at org.apache.catalina.startup.Catalina.start(Catalina.java:581)
	... 6 more

 

 

主要是这么一句:

Caused by: java.lang.UnsupportedClassVersionError: Bad version number in .class file (unable to load class cn.chenfeng.Listener.MySessionListener)

 

 

问题分析

 

网上搜了下,也有人遇到过类似问题,说是JDK版本不对,但是没有具体说怎么解决。

 

然后自己再研究了一下,发现确实是Tomcat使用的JDK版本不对,我的JavaWeb应用是基于JavaEE 6的,但是Tomcat使用的却是JDK 5,所以才会产生这样的异常。

 

 

问题解决

 

㈠ 如果是通过在工程上右击->“Run As”->“Run on Server” 启动Tomcat


Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 

 

 

① 如果是第一次跑,以前没有配置过Tomat,那么选择“Tomcat v6.0 Server”,点击“Next”,在下个画面的“JRE”选项中要选择JDK 6,当然如果你的Eclipse默认的JRE就是JDK 6那就没问题了。


Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 

 

 

② 如果已经配置过Tomcat,并且出现上述异常,那么打开Eclipse的“Window”菜单下的“Preferences”,在弹出的画面中选择“Server”->“Runtime Environments”,在右边选择你要配置的Server,点击“Edit”按钮,在弹出的画面中将JRE选择为JDK6,然后确定即可。


Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 

 

 

㈡ 如果是通过Eclipse中的Tomcat插件启动Tomcat


Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 

 

那么打开Eclipse的“Window”菜单下的“Preferences”,在弹出的画面中选择“Tomat”->“JVM设定”,将JRE选择为JDK6,然后确定即可。


Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 

 

 

 以上です。

 

 

 

 

 

  • Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 
  • 大小: 11.4 KB
  • Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 
  • 大小: 22.2 KB
  • Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 
  • 大小: 34.7 KB
  • Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 
  • 大小: 18.7 KB
  • Eclipse启动Tomcat报错: Bad version number in .class file
            
    
    博客分类: 经典异常解决应用服务器技术 java.lang.UnsupportedClassVersionErrorBad version number in .class fileEclipse启动Tomcat报错 
  • 大小: 18.1 KB