javaweb运行报错:has been compiled by a more recent version of the Java Runtime (class file version 55.0)

朴灿烈づ我的快乐病毒、 2022-12-24 04:48 331阅读 0赞

请求servlet时,网页会报HTTP状态 500 - 内部服务器错误

1.报错信息:

类型 异常报告

消息 实例化Servlet类[lagou.homework.servlet.LoginServlet]异常

描述 服务器遇到一个意外的情况,阻止它完成请求。

例外情况

  1. javax.servlet.ServletException: 实例化Servlet类[example.hello.servlet.LoginServlet]异常
  2. org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:544)
  3. org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
  4. org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:690)
  5. org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
  6. org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:616)
  7. org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
  8. org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:831)
  9. org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1634)
  10. org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
  11. java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
  12. java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
  13. org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
  14. java.lang.Thread.run(Thread.java:745)
  15. java.lang.UnsupportedClassVersionError: example/hello/servlet/LoginServlet has been compiled by a more recent version of the Java Runtime (class file version 55.0), this version of the Java Runtime only recognizes class file versions up to 52.0 (无法载入的.类 [example.homework.servlet.LoginServlet])
  16. org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2411)
  17. org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:855)
  18. org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1327)
  19. org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1180)
  20. org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:544)
  21. org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
  22. org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:690)
  23. org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
  24. org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:616)
  25. org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
  26. org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:831)
  27. org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1634)
  28. org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
  29. java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
  30. java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
  31. org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
  32. java.lang.Thread.run(Thread.java:745)

2.日志关键内容是:

has been compiled by a more recent version of the Java Runtime (class file version 55.0), this version of the Java Runtime only recognizes class file versions up to 52.0

3.原因:

当前的jre不能对程序进行编译,Tomcat的版本高于JDK的版本导致的,当前运行的jdk是1.8而我用的Tomcat版本是Tomcat 9所以就会出现这个问题。

4.解决方法:

要么降低Tomcat的版本号,要么用更高的版本的JRE。

这里我选择使用高版本的JRE:

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTI2NjA0NjQ_size_16_color_FFFFFF_t_70

重启服务器再次运行项目,问题解决。

发表评论

表情:
评论列表 (有 0 条评论,331人围观)

还没有评论,来说两句吧...

相关阅读