web.xml是web應用中載入有關servlet信息的重要配置文件,起着初始化servlet,filter等web程序的作用。
通常,全部的MVC框架都須要Web應用載入一個核心控制器。那採取什么方法載入這種核心控制器呢,servlet或filter成為了非常好的選擇。
由於它們會隨着web服務的啟用而自己主動的載入。
對於Struts 2框架而言。須要載入FilterDispatcher,
僅僅要Web應用負責載入FilterDispatcher,FilterDispatcher將會載入應用的Struts 2框架。
由於Struts 2將核心控制器設計成Filter。而不是一個普通Servlet。
故為了讓Web應用載入FilterDispacher。僅僅須要在web.xml文件里配置FilterDispatcher就可以。
在web.xml里面配置struts。假設是2.1.3之前的版本號,用 org.apache.struts2.dispatcher.FilterDispatcher。
以后的版本號則配置org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter。
<!-- 配置Struts 2框架的核心Filter -->
<filter>
<!-- 配置Struts 2核心Filter的名字 -->
<filter-name>struts2</filter-name>
<!-- 配置Struts 2核心Filter的實現類 -->
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
FilterDispatcher是struts2.0.x到2.1.2版本號的核心過濾器.!
StrutsPrepareAndExecuteFilter是自2.1.3開始就替代了FilterDispatcher的.! {org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter}
<init-param>
<param-name>config </param-name>
<param-value>struts-default.xml,struts-plugin.xml,/WEB-INF/struts.xml </param-value>
</init-param>
<init-param>
<!-- 配置Struts 2框架默認載入的Action包結構 -->
<param-name>actionPackages</param-name>
<param-value>org.apache.struts2.showcase.person</param-value>
</init-param>
<!-- 配置Struts 2框架的配置提供者類 -->
<init-param>
<param-name>configProviders </param-name>
<param-value>lee.MyConfigurationProvider</param-value>
</init-param>
<!-- 配置Struts 2框架的常量 -->
<init-param>
<param-name>truts.enable.DynamicMethodInvocation</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>struts.devMode</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>struts.objectFactory</param-name>
<param-value>spring</param-value>
</init-param>
</filter>
<!-- 配置Filter攔截的URL -->
<filter-mapping>
<!-- 配置Struts 2的核心FilterDispatcher攔截全部用戶請求 -->
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
當中有3個初始化參數有特殊意義:
config:該參數的值是一個以英文逗號(,)隔開的字符串,每一個字符串都是一個XML配置文件的位置。
Struts 2框架將自己主動載入該屬性指定的系列配置文件。
假設沒有指定該屬性則默認使用例如以下三個配置文件struts-default.xml,struts-plugin.xml,struts.xml
actionPackages:該參數的值也是一個以英文逗號(,)隔開的字符串。每一個字符串都是一個包空間,Struts 2框架將掃描這些包空間下的Action類。
configProviders:假設用戶須要實現自己的ConfigurationProvider類,用戶能夠提供一個或多個實現了ConfigurationProvider接口的類。
然后將這些類的類名設置成該屬性的值。多個類名之間以英文逗號(,)隔開。
除此之外,還可在此處配置Struts 2常量,每一個<init-param>元素配置一個Struts 2常量,當中<param-name>子元素指定了常量name,
而<param-value>子元素指定了常量value。
至於filter-mapping屬性是過濾器(Filter)必須的一個屬性,用於過濾請求的路徑,此處一般就設為/*形式,
對全部請求uri進行攔截(過濾),除非你要做一些特殊的處理。
到此,配置完struts2的核心控制器后,基本完畢了struts2在web.xml文件里的配置。
注意點:假設web容器是J2EE1.3(servlet2.3),因為不會自己主動載入struts的標簽庫,所以須要在web.xml文件里手動載入struts的標簽庫。
文件名稱struts-tags.tld,一般放在WEB-INF以下,能夠自己指定但假設web容器是J2EE1.4(servlet2.4),那么web容器會自己主動載入標簽庫,
Struts 2的標簽庫定義文件包括在struts2-core-2.0.6.jar文件中,在struts2-core-2.0.6.jar文件的META-INF路徑下。包括了一個struts-tag.tld文件,
這個文件就是Struts 2的標簽庫定義文件,Servlet 2.4規范會自己主動載入該標簽庫文件,當中struts-tags.tld文件中包括了載入信息的片斷:例如以下:
<taglib>
<!-- 定義標簽庫的版本號 -->
<tlib-version>2.2.3</tlib-version>
<!-- 定義標簽庫所需的JSP版 -->
<jsp-version>1.2</jsp-version>
<short-name>s</short-name>
<!-- 定義Struts 2標簽庫的URI。jsp文件里應用的uri-->
<uri>/struts-tags</uri>...
</taglib>
而servlet2.3手動配置例如以下:
<!-- 手動配置Struts 2的標簽庫 -->
<taglib>
<!-- 配置Struts 2標簽庫的URI jsp文件里應用的uri,類似於名字空間-->
<taglib-uri>/s</taglib-uri>
<!-- 指定Struts 2標簽庫定義文件的物理位置 -->
<taglib-location>/WEB-INF/struts-tags.tld</taglib-location>
</taglib>