天天看點

web.xml 中關于 MVC 的詳細配置

1、spring 架構解決字元串編碼問題:過濾器 CharacterEncodingFilter(filter-name) 

2、在web.xml配置監聽器ContextLoaderListener(listener-class) 

ContextLoaderListener的作用就是啟動Web容器時,自動裝配ApplicationContext的配置資訊。因為它實作了ServletContextListener這個接口,在web.xml配置這個監聽器,啟動容器時,就會預設執行它實作的方法。 

3、部署applicationContext的xml檔案:contextConfigLocation(context-param下的param-name) 

4、DispatcherServlet是前置控制器,配置在web.xml檔案中的。攔截比對的請求,Servlet攔截比對規則要自已定義,把攔截下來的請求,依據某某規則分發到目标Controller(我們寫的Action)來處理。 

DispatcherServlet(servlet-name、servlet-class、init-param、param-name(contextConfigLocation)、param-value) 

在DispatcherServlet的初始化過程中,架構會在web應用的 WEB-INF檔案夾下尋找名為[servlet-name]-servlet.xml 的配置檔案,生成檔案中定義的bean

<?xml version="1.0" encoding="UTF-8"?>  
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"  
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">  

    <!-- 在Spring架構中是如何解決從頁面傳來的字元串的編碼問題的呢?
    下面我們來看看Spring架構給我們提供過濾器CharacterEncodingFilter  
     這個過濾器就是針對于每次浏覽器請求進行過濾的,然後再其之上添加了父類沒有的功能即處理字元編碼。  
      其中encoding用來設定編碼格式,forceEncoding用來設定是否理會 request.getCharacterEncoding()方法,設定為true則強制覆寫之前的編碼格式。-->  
    <filter>  
        <filter-name>characterEncodingFilter</filter-name>  
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  
        <init-param>  
            <param-name>encoding</param-name>  
            <param-value>UTF-8</param-value>  
        </init-param>  
        <init-param>  
            <param-name>forceEncoding</param-name>  
            <param-value>true</param-value>  
        </init-param>  
    </filter>  
    <filter-mapping>  
        <filter-name>characterEncodingFilter</filter-name>  
        <url-pattern>/*</url-pattern>  
    </filter-mapping>  
    <!-- 項目中使用Spring 時,applicationContext.xml配置檔案中并沒有BeanFactory,要想在業務層中的class 檔案中直接引用Spring容器管理的bean可通過以下方式-->  
    <!--1、在web.xml配置監聽器ContextLoaderListener-->  
    <!--ContextLoaderListener的作用就是啟動Web容器時,自動裝配ApplicationContext的配置資訊。因為它實作了ServletContextListener這個接口,在web.xml配置這個監聽器,啟動容器時,就會預設執行它實作的方法。  
    在ContextLoaderListener中關聯了ContextLoader這個類,是以整個加載配置過程由ContextLoader來完成。  
    它的API說明  
    第一段說明ContextLoader可以由 ContextLoaderListener和ContextLoaderServlet生成。  
    如果檢視ContextLoaderServlet的API,可以看到它也關聯了ContextLoader這個類而且它實作了HttpServlet這個接口  
    第二段,ContextLoader建立的是 XmlWebApplicationContext這樣一個類,它實作的接口是WebApplicationContext->ConfigurableWebApplicationContext->ApplicationContext->  
    BeanFactory這樣一來spring中的所有bean都由這個類來建立  
     IUploaddatafileManager uploadmanager = (IUploaddatafileManager)    ContextLoaderListener.getCurrentWebApplicationContext().getBean("uploadManager");
     -->  
    <listener>  
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
    </listener>  
    <!--2、部署applicationContext的xml檔案-->  
    <!--如果在web.xml中不寫任何參數配置資訊,預設的路徑是"/WEB-INF/applicationContext.xml,  
    在WEB-INF目錄下建立的xml檔案的名稱必須是applicationContext.xml。  
    如果是要自定義檔案名可以在web.xml裡加入contextConfigLocation這個context參數:  
    在<param-value> </param-value>裡指定相應的xml檔案名,如果有多個xml檔案,可以寫在一起并以“,”号分隔。  
    也可以這樣applicationContext-*.xml采用通配符,比如這那個目錄下有applicationContext-ibatis-base.xml,  
    applicationContext-action.xml,applicationContext-ibatis-dao.xml等檔案,都會一同被載入。  
    在ContextLoaderListener中關聯了ContextLoader這個類,是以整個加載配置過程由ContextLoader來完成。-->  
    <context-param>  
        <param-name>contextConfigLocation</param-name>  
        <param-value>classpath:spring/applicationContext.xml</param-value>  
    </context-param>  

    <!--如果你的DispatcherServlet攔截"/",為了實作REST風格,攔截了所有的請求,那麼同時對*.js,*.jpg等靜态檔案的通路也就被攔截了。-->  
    <!--方案一:激活Tomcat的defaultServlet來處理靜态檔案-->  
    <!--要寫在DispatcherServlet的前面, 讓 defaultServlet先攔截請求,這樣請求就不會進入Spring了,我想性能是最好的吧。-->  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.css</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.swf</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.gif</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.jpg</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.png</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.js</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.html</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.xml</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.json</url-pattern>  
    </servlet-mapping>  
    <servlet-mapping>  
        <servlet-name>default</servlet-name>  
        <url-pattern>*.map</url-pattern>  
    </servlet-mapping>  
    <!--使用Spring MVC,配置DispatcherServlet是第一步。DispatcherServlet是一個Servlet,,是以可以配置多個DispatcherServlet-->  
    <!--DispatcherServlet是前置控制器,配置在web.xml檔案中的。攔截比對的請求,Servlet攔截比對規則要自已定義,把攔截下來的請求,依據某某規則分發到目标Controller(我們寫的Action)來處理。-->  
    <servlet>  
        <servlet-name>DispatcherServlet</servlet-name><!--在DispatcherServlet的初始化過程中,架構會在web應用的 WEB-INF檔案夾下尋找名為[servlet-name]-servlet.xml 的配置檔案,生成檔案中定義的bean。-->  
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
        <!--指明了配置檔案的檔案名,不使用預設配置檔案名,而使用dispatcher-servlet.xml配置檔案。-->  
        <init-param>  
            <param-name>contextConfigLocation</param-name>  
            <!--其中<param-value>**.xml</param-value> 這裡可以使用多種寫法-->  
            <!--1、不寫,使用預設值:/WEB-INF/<servlet-name>-servlet.xml-->  
            <!--2、<param-value>/WEB-INF/classes/dispatcher-servlet.xml</param-value>-->  
            <!--3、<param-value>classpath*:dispatcher-servlet.xml</param-value>-->  
            <!--4、多個值用逗号分隔-->  
            <param-value>classpath:spring/dispatcher-servlet.xml</param-value>  
        </init-param>  
        <load-on-startup>1</load-on-startup><!--是啟動順序,讓這個Servlet随Servletp容器一起啟動。-->  
    </servlet>  
    <servlet-mapping>  
        <!--這個Servlet的名字是dispatcher,可以有多個DispatcherServlet,是通過名字來區分的。每一個DispatcherServlet有自己的WebApplicationContext上下文對象。同時儲存的ServletContext中和Request對象中.-->  
        <!--ApplicationContext是Spring的核心,Context我們通常解釋為上下文環境,我想用“容器”來表述它更容易了解一些,ApplicationContext則是“應用的容器”了:P,Spring把Bean放在這個容器中,在需要的時候,用getBean方法取出-->  
        <servlet-name>DispatcherServlet</servlet-name>  
        <!--Servlet攔截比對規則可以自已定義,當映射為@RequestMapping("/user/add")時,為例,攔截哪種URL合适?-->  
        <!--1、攔截*.do、*.htm, 例如:/user/add.do,這是最傳統的方式,最簡單也最實用。不會導緻靜态檔案(jpg,js,css)被攔截。-->  
        <!--2、攔截/,例如:/user/add,可以實作現在很流行的REST風格。很多網際網路類型的應用很喜歡這種風格的URL。弊端:會導緻靜态檔案(jpg,js,css)被攔截後不能正常顯示。 -->  
        <url-pattern>/</url-pattern> <!--會攔截URL中帶“/”的請求。-->  
    </servlet-mapping>  

    <welcome-file-list><!--指定歡迎頁面-->  
        <welcome-file>login.html</welcome-file>  
    </welcome-file-list>  
    <error-page> <!--當系統出現404錯誤,跳轉到頁面nopage.html-->  
        <error-code>404</error-code>  
        <location>/nopage.html</location>  
    </error-page>  
    <error-page> <!--當系統出現java.lang.NullPointerException,跳轉到頁面error.html-->  
        <exception-type>java.lang.NullPointerException</exception-type>  
        <location>/error.html</location>  
    </error-page>  
    <session-config><!--會話逾時配置,機關分鐘-->  
        <session-timeout>360</session-timeout>  
    </session-config>  
</web-app>        

繼續閱讀