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

问题现象

 

在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


 

 

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


 

 

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


 

 

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


 

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


 

 

 以上です。

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值