web應用啓動過程

web.xml節點啓動順序:context-param -> listener -> filter -> 特定servlethtml

ServletContext從一啓動的時候就存在,關閉項目的時候才關閉。java

具體參考:https://www.cnblogs.com/xiaoma000deblog/p/10298526.htmlweb

web.xml部分節點:spring

一、指定歡迎頁面,例如:
<welcome-file-list>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
<welcome-file>index1.jsp</welcome-file>
</welcome-file-list>
上面的例子指定了2個歡迎頁面,顯示時按順序從第一個找起,若是第一個存在,就顯示第一個,後面的不起做用。若是第一個不存在,就找第二個,以此類推。
關於歡迎頁面:
訪問一個網站時,默認看到的第一個頁面就叫歡迎頁,通常狀況下是由首頁來充當歡迎頁的。通常狀況下,咱們會在web.xml中指定歡迎頁。但web.xml 並非一個Web的必要文件,沒有web.xml,網站仍然是能夠正常工做的。只不過網站的功能複雜起來後,web.xml的確有很是大用處,因此,默認建立的動態web工程在WEB-INF文件夾下面都有一個web.xml文件。
對於tomcat來講,當你只指定一個web的根名,沒有指定具體頁面,去訪問時一個web時,若是web.xml文件中配置了歡迎頁,那麼就返回指定的那個頁面做爲歡迎頁,而在文中沒有web.xml文件,或雖然有web.xml,但 web.xml也沒指定歡迎頁的狀況下,它默認先查找index.html文件,若是找到了,就把index.html做爲歡迎頁還回給瀏覽器。若是沒找到index.html,tomcat就去找index.jsp。找到index.jsp就把它做爲歡迎頁面返回。而若是index.html和 index.jsp都沒找到,又沒有用web.xml文件指定歡迎頁面,那此時tomcat就不知道該返回哪一個文件了,它就顯示The requested resource (/XXX) is not available的頁面。其中XXX表示web的根名。但若是你指定了具體頁面,是能夠正常訪問的。
二、命名與定製URL。咱們能夠爲Servlet和JSP文件命名並定製URL,其中定製URL是依賴一命名的,命名必須在定製URL前。下面拿serlet來舉例:
(1)、爲Servlet命名:
<servlet>
<servlet-name>servlet1</servlet-name>
<servlet-class>net.test.TestServlet</servlet-class>
</servlet>
(2)、爲Servlet定製URL、
<servlet-mapping>
<servlet-name>servlet1</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>

三、定製初始化參數:能夠定製servlet、JSP、Context的初始化參數,而後能夠再servlet、JSP、Context中獲取這些參數值。下面哪servlet來舉例:
<servlet>
<servlet-name>servlet1</servlet-name>
<servlet-class>net.test.TestServlet</servlet-class>
<init-param>
<param-name>userName</param-name>
<param-value>Tommy</param-value>
</init-param>
<init-param>
<param-name>E-mail</param-name>
<param-value>Tommy@163.com</param-value>
</init-param>
</servlet>
通過上面的配置,在servlet中可以調用getServletConfig().getInitParameter("param1")得到參數名對應的值。
四、指定錯誤處理頁面,能夠經過「異常類型」或「錯誤碼」來指定錯誤處理頁面。
<error-page>
<error-code>404</error-code>
<location>/error404.jsp</location>
</error-page>
-----------------------------
<error-page>
<exception-type>java.lang.Exception<exception-type>
<location>/exception.jsp<location>
</error-page>
五、設置過濾器:好比設置一個編碼過濾器,過濾全部資源
<filter>
<filter-name>XXXCharaSetFilter</filter-name>
<filter-class>net.test.CharSetFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>XXXCharaSetFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>瀏覽器

 

<!-- characterEncodingFilter字符編碼過濾器 --> tomcat

<filter> session

<filter-name>characterEncodingFilter</filter-name> app

<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> jsp

<init-param> post

<!--要使用的字符集,通常咱們使用UTF-8(保險起見UTF-8最好)-->

<param-name>encoding</param-name>

<param-value>UTF-8</param-value>

</init-param>

<init-param>

<!--是否強制設置request的編碼爲encoding,默認false,不建議更改-->

<param-name>forceRequestEncoding</param-name>

<param-value>false</param-value>

</init-param>

<init-param>

<!--是否強制設置response的編碼爲encoding,建議設置爲true,下面有關於這個參數的解釋-->

<param-name>forceResponseEncoding</param-name>

<param-value>true</param-value>

</init-param>

</filter>

<filter-mapping>

<filter-name>characterEncodingFilter</filter-name>

<!--這裏不能留空或者直接寫 ' / ' ,否者不起做用-->

<url-pattern>/*</url-pattern>

</filter-mapping>

這段代碼的做用是設置response的默認編碼方式,在以後的代碼裏是能夠根據需求設置爲其餘編碼的,即這裏設置的編碼可能不是最終的編碼


六、設置監聽器:
<listener>
<listener-class>net.test.XXXLisenet</listener-class>
</listener>
七、設置會話(Session)過時時間,其中時間以分鐘爲單位,假如設置60分鐘超時:
<session-config>
<session-timeout>60</session-timeout>
</session-config>

 

servlet容器和web應用的關係:

JavaWeb應用的生命週期是由Servlet容器來控制的。包括三個階段:

1.啓動階段:加載Web應用的有關數據,建立ServletContest對象,對Filter(過濾器)和一些Servlet進行初始化。啓動時會:

  (1)把web.xml文件中的數據加載到內存中。

  (2)爲JavaWeb應用建立一個ServletContext對象。

  (3)對全部的Filter進行初始化。

  (4)對須要在Web應用啓動時就被初始化的Servlet進行初始化。

2.運行階段:爲客戶端提供服務。

  JavaWeb應用最主要的聲明階段,此階段,全部的Servlet都處於待命狀態,隨時能夠響應客戶端的特定請求,提供相應的服務。若客戶端請求的Servlet不存在,Servlet容器會先初始化Servlet,而後調用它的Service服務方法。

3.終止階段:釋放Web應用所佔用的各類資源。終止時會:

  (1)銷燬JavaWeb應用中全部處於運行狀態的Servlet。

  (2)銷燬JavaWeb應用中全部處於運行時狀態的Filter。  

  (3)銷燬全部與JavaWeb應用相關的對象,如ServlerContext對象等,而且釋放Web應用所佔用的相關資源。

具體參考:https://www.cnblogs.com/sjxbg/p/8905843.html

 

實現本身的filter:

一、實現HandlerInterceptor:MySpringFilter implements HandlerInterceptor

二、繼承HandlerInterceptorAdapter:MySpringFilter extends HandlerInterceptorAdapter

HandlerInterceptor具體方法和做用:

public interface HandlerInterceptor { /** * 預處理回調方法,實現處理器的預處理(如檢查登錄),第三個參數爲響應的處理器,自定義Controller * 返回值:true表示繼續流程(如調用下一個攔截器或處理器);false表示流程中斷(如登陸檢查失敗),不會繼續調用其餘的攔截器或處理器,此時咱們須要經過response來產生響應; */ boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception; /** * 後處理回調方法,實現處理器的後處理(但在渲染視圖以前),此時咱們能夠經過modelAndView(模型和視圖對象)對模型數據進行處理或對視圖進行處理,modelAndView也可能爲null。 */ void postHandle( HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception; /** * 整個請求處理完畢回調方法,即在視圖渲染完畢時回調,如性能監控中咱們能夠在此記錄結束時間並輸出消耗時間,還能夠進行一些資源清理,相似於try-catch-finally中的finally,但僅調用處理器執行鏈中 */ void afterCompletion( HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception; }

參考:https://www.jianshu.com/p/1e8d088c2be9

相關文章
相關標籤/搜索