工作原理:
在Struts2框架中的處理大概分爲以下幾個步驟
1 客戶端初始化一個指向Servlet容器(例如Tomcat)的請求
2 這個請求經過一系列的過濾器(Filter)(這些過濾器中有一個叫做ActionContextCleanUp的可選過濾器,這個過濾器對於Struts2和其他框架的集成很有幫助,例如:SiteMesh Plugin)
3 接着FilterDispatcher被調用,FilterDispatcher詢問ActionMapper來決定這個請是否需要調用某個Action
4 如果ActionMapper決定需要調用某個Action,FilterDispatcher把請求的處理交給ActionProxy
5 ActionProxy通過Configuration Manager詢問框架的配置文件,找到需要調用的Action類
6 ActionProxy創建一個ActionInvocation的實例。
7 ActionInvocation實例使用命名模式來調用,在調用Action的過程前後,涉及到相關攔截器(Intercepter)的調用。
8 一旦Action執行完畢,ActionInvocation負責根據struts.xml中的配置找到對應的返回結果。返回結果通常是(但不總是,也可 能是另外的一個Action鏈)一個需要被表示的JSP或者FreeMarker的模版。在表示的過程中可以使用Struts2 框架中繼承的標籤。在這個過程中需要涉及到ActionMapper
配置注意
一、struts 2.5中xwork-core包已經被整合在struts-core包裏了,所以只需要導入核心包;
二、struts 2.5中攔截器更換爲org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter;
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
三、有幾個小細節需要注意:struts的配置文件應該爲struts.xml而不是struts2.xml;而且struts配置文件中對於package中的extends屬性也需要注意,<struts>
<package name="default" namespace="/" extends="struts-default">
<action name="helloworld" class="com.zyw.action.HelloWorldAction">
<result>/result.jsp</result>
</action>
</package>
</struts>
關於通配符無法使用的問題
問題分析:struts2.5爲了安全問題,在struts.xml的package標籤中新增了一個子標籤:global-allowed-methods。
解決方法:在package標籤中添加global-allowed-methods子標籤
<package name="default" namespace="/" extends="struts-default">
<global-allowed-methods>regex:.*</global-allowed-methods>
<action name=" " method=" " class=" ">
<result> </result>
</action>
</package>