使用IDEA配置Tomcat访问web
再l下配置好了如下:
这样再浏览器中输入localhost:8080/s1/hello 就可以访问到HelloServlet这个类的类容。但就是访问不到,找了很久都没有什么问题。
第一次访问
第二次访问:
HTTP状态 500 - 内部服务器错误
类型 异常报告消息 实例化Servlet类[servlet.HelloServlet]异常描述 服务器遇到一个意外的情况,阻止它完成请求。例外情况jakarta.servlet.ServletException: 实例化Servlet类[servlet.HelloServlet]异常org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:542)org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:690)org.tor.CoyoteAdapter.service(CoyoteAdapter.java:356)http11.Http11Processor.service(Http11Processor.java:399)AbstractProcessorLight.process(AbstractProcessorLight.java:65)AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:867)at.util.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1760)at.util.SocketProcessorBase.run(SocketProcessorBase.java:49)at.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191)at.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659)at.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)java.lang.Thread.run(Thread.java:748)
根本原因。java.lang.NoClassDefFoundError: javax/servlet/http/HttpServletjava.lang.ClassLoader.defineClass1(Native Method)java.lang.ClassLoader.defineClass(ClassLoader.java:763)java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2510)org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:877)org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1413)org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1257)org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:542)org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:690)org.tor.CoyoteAdapter.service(CoyoteAdapter.java:356)http11.Http11Processor.service(Http11Processor.java:399)AbstractProcessorLight.process(AbstractProcessorLight.java:65)AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:867)at.util.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1760)at.util.SocketProcessorBase.run(SocketProcessorBase.java:49)at.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191)at.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659)at.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)java.lang.Thread.run(Thread.java:748)
根本原因。java.lang.ClassNotFoundException: javax.servlet.http.HttpServletorg.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1449)org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1257)java.lang.ClassLoader.defineClass1(Native Method)java.lang.ClassLoader.defineClass(ClassLoader.java:763)java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2510)org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:877)org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1413)org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1257)org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:542)org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:690)org.tor.CoyoteAdapter.service(CoyoteAdapter.java:356)http11.Http11Processor.service(Http11Processor.java:399)AbstractProcessorLight.process(AbstractProcessorLight.java:65)AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:867)at.util.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1760)at.util.SocketProcessorBase.run(SocketProcessorBase.java:49)at.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191)at.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659)at.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)java.lang.Thread.run(Thread.java:748)
):注意 主要问题的全部 stack 信息可以在 server logs 里查看
出现这个问题的原因是tomcat 10中的servlet-api与maven中导入的servlet-api依赖不兼容所导致的。
我使用tomcat 9.0.65的版本就可以了。
本文发布于:2024-01-29 05:40:40,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170647804513094.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |