Tomcat 與 Servlet 是如何工作的:

步驟:
Web Client 向Servlet容器(Tomcat)發出Http請求Servlet容器接收Web Client的請求Servlet容器創建一個HttPRequest對象,將Web Client請求的信息封裝到這個對象中。Servlet容器創建一個HttpResponse對象Servlet容器調用HttpServlet對象的service方法,把HttpRequest對象與HttpResponse對象作為參數傳給 HttpServlet 對象。HttpServlet調用HttpRequest對象的有關方法,獲取Http請求信息。HttpServlet調用HttpResponse對象的有關方法,生成響應數據。Servlet容器把HttpServlet的響應結果傳給Web Client。
Servlet工作原理:
1、首先簡單解釋一下Servlet接收和響應客戶請求的過程,首先客戶發送一個請求,Servlet是調用service()方法對請求進行響應的,通過源代碼可見,service()方法中對請求的方式進行了匹配,選擇調用doGet,doPost等這些方法,然后再進入對應的方法中調用邏輯層的方法,實現對客戶的響應。在Servlet接口和GenericServlet中是沒有doGet()、doPost()等等這些方法的,HttpServlet中定義了這些方法,但是都是返回error信息,所以,我們每次定義一個Servlet的時候,都必須實現doGet或doPost等這些方法。
2、每一個自定義的Servlet都必須實現Servlet的接口,Servlet接口中定義了五個方法,其中比較重要的三個方法涉及到Servlet的生命周期,分別是上文提到的init(),service(),destroy()方法。GenericServlet是一個通用的,不特定于任何協議的Servlet,它實現了Servlet接口。而HttpServlet繼承于GenericServlet,因此HttpServlet也實現了Servlet接口。所以我們定義Servlet的時候只需要繼承HttpServlet即可。
3、Servlet接口和GenericServlet是不特定于任何協議的,而HttpServlet是特定于HTTP協議的類,所以HttpServlet中實現了service()方法,并將請求ServletRequest、ServletResponse 強轉為HttpRequest 和 HttpResponse。
創建Servlet對象的時機:
Servlet容器啟動時:讀取web.xml配置文件中的信息,構造指定的Servlet對象,創建ServletConfig對象,同時將ServletConfig對象作為參數來調用Servlet對象的init方法。在Servlet容器啟動后:客戶首次向Servlet發出請求,Servlet容器會判斷內存中是否存在指定的Servlet對象,如果沒有則創建它,然后根據客戶的請求創建HttpRequest、HttpResponse對象,從而調用Servlet 對象的service方法。Servlet Servlet容器在啟動時自動創建Servlet,這是由在web.xml文件中為Servlet設置的<load-on-startup>屬性決定的。從中我們也能看到同一個類型的Servlet對象在Servlet容器中以單例的形式存在。<servlet> <servlet-name>Init</servlet-name> <servlet-class>org.xl.servlet.InitServlet</servlet-class> <load-on-startup>1</load-on-startup></servlet>
原文自:http://www.cnblogs.com/xuekyo/archive/2013/02/24/2924072.html-------------------------------------------------------------Servlet生命周期與工作原理Servlet生命周期分為三個階段:
1,初始化階段 調用init()方法
2,響應客戶請求階段 調用service()方法
3,終止階段 調用destroy()方法
Servlet初始化階段:
在下列時刻Servlet容器裝載Servlet:
1,Servlet容器啟動時自動裝載某些Servlet,實現它只需要在web.XML文件中的<Servlet></Servlet>之間添加如下代碼:
<loadon-startup>1</loadon-startup> |
2,在Servlet容器啟動后,客戶首次向Servlet發送請求
3,Servlet類文件被更新后,重新裝載Servlet
Servlet被裝載后,Servlet容器創建一個Servlet實例并且調用Servlet的init()方法進行初始化。在Servlet的整個生命周期內,init()方法只被調用一次。
Servlet工作原理:
首先簡單解釋一下Servlet接收和響應客戶請求的過程,首先客戶發送一個請求,Servlet是調用service()方法對請求進行響應的,通過源代碼可見,service()方法中對請求的方式進行了匹配,選擇調用doGet,doPost等這些方法,然后再進入對應的方法中調用邏輯層的方法,實現對客戶的響應。在Servlet接口和GenericServlet中是沒有doGet,doPost等等這些方法的,HttpServlet中定義了這些方法,但是都是返回error信息,所以,我們每次定義一個Servlet的時候,都必須實現doGet或doPost等這些方法。
每一個自定義的Servlet都必須實現Servlet的接口,Servlet接口中定義了五個方法,其中比較重要的三個方法涉及到Servlet的生命周期,分別是上文提到的init(),service(),destroy()方法。GenericServlet是一個通用的,不特定于任何協議的Servlet,它實現了Servlet接口。而HttpServlet繼承于GenericServlet,因此HttpServlet也實現了Servlet接口。所以我們定義Servlet的時候只需要繼承HttpServlet即可。
Servlet接口和GenericServlet是不特定于任何協議的,而HttpServlet是特定于HTTP協議的類,所以HttpServlet中實現了service()方法,并將請求ServletRequest,ServletResponse強轉為HttpRequest和HttpResponse。
public void service(ServletRequest req,ServletResponse res) throws ServletException,IOException{ HttpRequest request; HttpResponse response; try { req = (HttpRequest)request; res = (HttpResponse)response; }catch(ClassCastException e) { throw new ServletException("non-HTTP request response"); } service(request,response);} |
代碼的最后調用了HTTPServlet自己的service(request,response)方法,然后根據請求去調用對應的doXXX方法,因為HttpServlet中的doXXX方法都是返回錯誤信息,
protected void doGet(HttpServletRequest res,HttpServletResponse resp) throws ServletException,IOException{ String protocol = req.getProtocol(); String msg = IStrings.getString("http.method_get_not_supported"); if(protocol.equals("1.1")) { resp.sendError(HttpServletResponse.SC.METHOD.NOT.ALLOWED,msg); } esle { resp.sendError(HttpServletResponse.SC_BAD_REQUEST,msg); }} |
所以需要我們在自定義的Servlet中override這些方法!
源碼面前,了無秘密!
---------------------------------------------------------------------------------------------------------------------------------
Servlet響應請求階段:
對于用戶到達Servlet的請求,Servlet容器會創建特定于這個請求的ServletRequest對象和ServletResponse對象,然后調用Servlet的service方法。service方法從ServletRequest對象獲得客戶請求信息,處理該請求,并通過ServletResponse對象向客戶返回響應信息。
對于Tomcat來說,它會將傳遞過來的參數放在一個Hashtable中,該Hashtable的定義是:
private Hashtable<String String[]> paramHashStringArray = new Hashtable<String String[]>(); |
這是一個String-->String[]的鍵值映射。
HashMap線程不安全的,Hashtable線程安全。
-----------------------------------------------------------------------------------------------------------------------------------
Servlet終止階段:
當WEB應用被終止,或Servlet容器終止運行,或Servlet容器重新裝載Servlet新實例時,Servlet容器會先調用Servlet的destroy()方法,在destroy()方法中可以釋放掉Servlet所占用的資源。
-----------------------------------------------------------------------------------------------------------------------------------
Servlet何時被創建:
1,默認情況下,當WEB客戶第一次請求訪問某個Servlet的時候,WEB容器將創建這個Servlet的實例。
2,當web.xml文件中如果<servlet>元素中指定了<load-on-startup>子元素時,Servlet容器在啟動web服務器時,將按照順序創建并初始化Servlet對象。
注意:在web.xml文件中,某些Servlet只有<serlvet>元素,沒有<servlet-mapping>元素,這樣我們無法通過url的方式訪問這些Servlet,這種Servlet通常會在<servlet>元素中配置一個<load-on-startup>子元素,讓容器在啟動的時候自動加載這些Servlet并調用init()方法,完成一些全局性的初始化工作。
Web應用何時被啟動:
1,當Servlet容器啟動的時候,所有的Web應用都會被啟動
2,控制器啟動web應用
-----------------------------------------------------------------------------------------------------------------------------------------------
Servlet與jsp的比較:
有許多相似之處,都可以生成動態網頁。
JSP的優點是擅長于網頁制作,生成動態頁面比較直觀,缺點是不容易跟蹤與排錯。
Servlet是純java語言,擅長于處理流程和業務邏輯,缺點是生成動態網頁不直觀
原文自:http://www.cnblogs.com/cuiliang/archive/2011/10/21/2220671.html
新聞熱點
疑難解答