Servlet生命週期分爲三個階段:html
1,初始化階段 調用init()方法java
2,響應客戶請求階段 調用service()方法web
3,終止階段 調用destroy()方法安全
Servlet初始化階段:服務器
在下列時刻Servlet容器裝載Servlet:app
1,Servlet容器啓動時自動裝載某些Servlet,實現它只須要在web.XML文件中的<Servlet></Servlet>之間添加以下代碼:ide
1 <loadon-startup>1</loadon-startup>
2,在Servlet容器啓動後,客戶首次向Servlet發送請求ui
3,Servlet類文件被更新後,從新裝載Servleturl
Servlet被裝載後,Servlet容器建立一個Servlet實例而且調用Servlet的init()方法進行初始化。在Servlet的整個生命週期內,init()方法只被調用一次。spa
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。
1 public void service(ServletRequest req,ServletResponse res) 2 3 throws ServletException,IOException 4 5 { 6 7 HttpRequest request; 8 9 HttpResponse response; 10 11 12 13 try 14 15 { 16 17 req = (HttpRequest)request; 18 19 res = (HttpResponse)response; 20 21 }catch(ClassCastException e) 22 23 { 24 25 throw new ServletException("non-HTTP request response"); 26 27 } 28 29 service(request,response); 30 31 }
代碼的最後調用了HTTPServlet本身的service(request,response)方法,而後根據請求去調用對應的doXXX方法,由於HttpServlet中的doXXX方法都是返回錯誤信息,
1 protected void doGet(HttpServletRequest res,HttpServletResponse resp) 2 3 throws ServletException,IOException 4 5 { 6 7 String protocol = req.getProtocol(); 8 9 String msg = IStrings.getString("http.method_get_not_supported"); 10 11 if(protocol.equals("1.1")) 12 13 { 14 15 resp.sendError(HttpServletResponse.SC.METHOD.NOT.ALLOWED,msg); 16 17 } 18 19 esle 20 21 { 22 23 resp.sendError(HttpServletResponse.SC_BAD_REQUEST,msg); 24 25 } 26 27 }
因此須要咱們在自定義的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