Servletle類實例化錯誤


Tomcat和Servlet

HTTP狀態 500 - 內部服務器錯誤
類型 異常報告

消息 實例化Servlet類[servlet.ServletHello]異常

描述 服務器遇到一個意外的情況,阻止它完成請求。

例外情況

jakarta.servlet.ServletException: 實例化Servlet類[servlet.ServletHello]異常
    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:693)
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:339)
    org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:373)
    org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
    org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:845)
    org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1562)
    org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    java.lang.Thread.run(Thread.java:745)
根本原因。

java.lang.NoClassDefFoundError: javax/servlet/http/HttpServlet
    java.lang.ClassLoader.defineClass1(Native Method)
    java.lang.ClassLoader.defineClass(ClassLoader.java:760)
    java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2417)
    org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:864)
    org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1333)
    org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1187)
    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:693)
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:339)
    org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:373)
    org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
    org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:845)
    org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1562)
    org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    java.lang.Thread.run(Thread.java:745)
根本原因。

java.lang.ClassNotFoundException: javax.servlet.http.HttpServlet
    org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1364)
    org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1187)
    java.lang.ClassLoader.defineClass1(Native Method)
    java.lang.ClassLoader.defineClass(ClassLoader.java:760)
    java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2417)
    org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:864)
    org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1333)
    org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1187)
    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:693)
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:339)
    org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:373)
    org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
    org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:845)
    org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1562)
    org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    java.lang.Thread.run(Thread.java:745)
):注意 主要問題的全部 stack 信息可以在 server logs 里查看

為了解決這個問題花了很久的時間,最終的解決方法是把tomcat換成9.*版本的,出現這個問題的原因是tomcat 10中的servlet-api與maven中導入的servlet-api依賴不兼容所導致的。在這里貼上我的百度到的鏈接。

https://blog.csdn.net/qq_42133677/article/details/106521854

我的探索歷程

環境:

 

使用的tomcat版本是:10.0.0-M7(alpha)(即內測版),配置是:

 

 

 

 

歷程:

起初我在瀏覽器使用的url為:

http://localhost:8080/Class9_war_exploded/

此url是有效的,能成功訪問到index.jsp。
當時web.xml配置文件內容如下:

<!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
  <display-name>Archetype Created Web Application</display-name>
  <servlet>
    <!--別名-->
    <servlet-name>hello</servlet-name>
    <!--類路徑,由包名.類名組成-->
    <servlet-class>servlet.ServletHello</servlet-class>
  </servlet>
  <servlet-mapping> <!--用來定義servlet所對應的url-->
    <servlet-name>hello</servlet-name>
    <url-pattern>/hello</url-pattern> <!--頁面路由時路徑 僅為hello時報錯 也就是說,如果站點下只有一個web項目時,例如
         http://localhost:8080/可以訪問到index.jsp,則http://localhost:8080/hello可以映射訪問到servlet.ServletHello
         的實例化對象-->
  </servlet-mapping>
</web-app>

類ServletHello的源碼如下:

public class ServletHello extends HttpServlet {  //該父類來自引入的jar包
//    public ServletHello() {
//        System.out.println("Hello");
//    }

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        PrintWriter out= resp.getWriter();
        resp.setContentType("text/html");
        out.println("Hello doGet");
    }

    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        String name=req.getParameter("name");
        PrintWriter out= resp.getWriter();
        resp.setContentType("text/html");
        out.println("Hello service"+name);
    }
}

當我使用url: http://localhost:8080/hello時就出現了文章開頭所示的錯誤。而且這種情況刷新一下就會變成404。我也試過不使用maven導入的依賴,但還是一樣的情況,最終我將tomcat換成了apache-tomcat-9.0.37版本的才成功跑起來,該url可成功訪問。

Tomcat和Servlet
這里我再說說我對Tomcat和項目中Servlet相關類的理解。
首先,Tomcat是服務器,也可以理解為一個容器,一個運行環境(主要容納和運行jsp、servlet)。tomcat部署成功后就可以直接運行web項目了。
如果我上面所提到的那篇文章中所提到的不假的話,那么我們可以推斷,servlet相關子類中的javax.servlet-api jar包時要和tomcat下lib中的javax.servlet-api jar包符合的。這個可以體現出容器或者運行環境的特質。比如應用與操作系統的關系。

Servlet是一個服務器類,它是容器所存放的內容,直接與Tomcat進行交互的(請求和響應)(底層原理應該包含Socket)。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM