1.加載時機
當應用被服務器加載時,Struts的配置文件就已經加載了
2.加載順序
default.properties------->struts-default.xml--------->struts-plugin.xml------------>struts.properties-------------->web.xml
順序 |
配置文件名 |
所在位置 |
說明 |
1 |
default.properties |
struts2-core-2.3.15.3.jar\org\apache\struts2 |
不能修改 |
2 |
struts-default.xml |
struts2-core-2.3.15.3.jar |
不能修改 |
3 |
strtuts-plugin.xml |
在struts2提供的插件jar包中 |
不能修改 |
4 |
struts.xml |
我們的應用中 |
我們修改的:推薦 |
5 |
struts.properties |
我們的應用中 |
我們修改的 |
6 |
web.xml |
我們的應用中 |
我們修改的,可以給過濾器配置參數 |
注意:
1、Struts2提供了兩種配置的方式。一種是key=value的方式,即使用.properties文件。另一種是xml文件配置。我們推薦使用xml文件(它能描述層級關系)。
2、當多個配置文件中,有相同的參數,后面的會把前面的值給覆蓋了。
3、Struts2框架提供的常量
a、常用的常量
常量定義在了default.properties配置文件中,體現形式都是key=value。所有的struts2應用都會用到這些常量。
常用的:
常量名 |
常量值 |
說明 |
struts.i18n.encoding |
UTF-8 |
應用中使用的編碼 |
struts.objectFactory.spring.autoWire |
name |
和spring框架整合有關 |
struts.multipart.parser |
jakarta |
指定文件上傳用的組件 |
struts.multipart.maxSize |
2097152 |
文件上傳總文件大小限制:2M |
struts.action.extension |
action,, |
能進入Struts2框架內部的url地址后綴名。多個值用逗號分隔 |
struts.enable.DynamicMethodInvocation |
false |
是否允許動態方法調用 |
struts.devMode |
false |
是否是開發模式。開發模式:改了配置文件,不需要重啟。輸出更多的錯誤信息。開發階段建議為true。 |
struts.ui.theme |
xhtml |
頁面展示用的主題 |
b、在struts.xml中覆蓋常量
使用<constant name="" value=""></constant>元素進行覆蓋
例如:
4、xml配置文件的主要元素
a、package元素
a.1、作用:
在struts2的配置文件中引入了面向對象思想,使用了分包管理。易於管理動作類。便於模塊化開發動作類。
a.2、屬性:
name:包的名稱。必須寫。且必須唯一。
extends:一般情況下需要繼承struts-default包,但不是必須的。不過如果不繼承的話,將無法使用struts2提供的核心功能。
struts-default.xml中定義着struts-default這個包。而struts-default.xml是在我們的struts.xml加載之前加載。
abstract:把包聲明為抽象包,抽象包就是用來被繼承的。只要是沒有<action>元素的包,就可以聲明為抽象包。
namespace:名稱空間。
名稱空間 + 動作名稱 = 訪問路徑
namespace的默認值:
a.不寫該屬性
b.寫了該屬性,取值是一個"".
注意:默認值不是/
動作類的搜索順序:
b、action元素
b.1、作用:
配置動作用的。
b.2、屬性:
name:動作名稱
class:動作類全名。默認的動作類是:com.opensymphony.xwork2.ActionSupport
是在struts-default.xml中定義的
要想替換默認動作類:
在應用的struts.xml中,package中加入:
method:動作類中的方法名稱。默認是public String execute(){}
要求:
1.public的
2.返回值必須是String
3.沒有參數
b.3、動作類
a.方式一:動作類就是一個POJO(Plain Old Java Object 原始的java對象),非常簡單的javabean。
b.方式二:動作類實現com.opensymphony.xwork2.Action接口。
常量:給動作方法返回值用的。用常量可以使你的應用規范和統一。
常量變量名 |
對應的值 |
說明 |
SUCCESS |
success |
動作方法執行一切OK |
ERROR |
error |
動作方法執行時遇到了異常 |
INPUT |
input |
回顯 |
LOGIN |
login |
一般轉向登陸頁面 |
NONE |
none |
不轉向任何的視圖 |
c.方式三:動作類繼承com.opensymphony.xwork2.ActionSupport 推薦使用
b.4、動作的訪問
優先級:絕對匹配優先。使用通配符的按照在配置文件中的先后順序進行匹配的。
通配符
5、結果類型視圖(邏輯結果視圖)
前奏:該部分內容指的就是struts配置文件中的result元素的使用
c.1、result元素
作用:
為動作指定結果視圖
屬性:
name:邏輯視圖的名稱,對應着動作方法的返回值。默認值是success。
type:結果類型,指的就是用什么方式轉到定義的頁面。默認是dispatcher。
dispatcher:(默認值) 使用請求轉發,轉向一個頁面。
redirect: 使用重定向,轉向一個頁面。
redirectAction:注意:使用的是重定向。
a.重定向到另一個相同名稱空間的動作。
b.重定向到不同名稱空間的動作
chain:注意: 使用的是請求轉發。
a.轉發到另一個相同名稱空間的動作。
b.請求轉發到不同名稱空間的動作
c.2: result元素中param子元素
在轉發或者重定向到不同包下的動作時,都用到了result元素的子元素param。
param元素的作用:依賴注入(Dependence Injection)思想
我們通過struts-default.xml中的resultTypes元素中配置可以看出, 每個結果類型視圖其實都是靠一個類來實現的。
而param元素就是將配置的參數,注入到該類中。
調用的是對應類的setter方法進行注入的。
例如:redirectAction結果視圖
該類中肯定會有對actionName和namespace屬性的注入方法(setter方法)。
默認結果視圖dispatcher
4、自定義結果類型
通過前面的內容,我們看出,其實結果類型就是一個類,這些類都實現了com.opensymphony.xwork2.Result接口。
或者繼承自該接口的實現類org.apache.struts2.dispatcher.StrutsResultSupport。
這些類都有一個doExecute方法,用於執行結果視圖。
綜上:我們也可以自己寫一個結果視圖。
例子:
輸出CAPTCHA圖像的結果類型。
CAPTCHA(Completely Automated Public Turing Test to Tell Computers and Humans Apart 全自動區分計算機和人類的圖靈測試)————>簡稱:驗證碼。
第一步:寫一個類,實現接口或者繼承接口的實現類
第二步:在struts.xml文件中配置結果類型
第三步:在action配置時引用
6、全局視圖和局部視圖
6.1、局部視圖
6.2、全局視圖(配置在global中)
7、在動作類中訪問Servlet的API
第一種方式:使用ServletActionContext類
ServletActionContext.getrequest.----------------
第二種方式:使用實現接口的方式
1.ServletRequestAware(request)
2. ServletResponseAware(response)
implements ServletRequestAware,ServletResponseAware
8、分文件編寫框架配置文件
2、分文件編寫Struts2的配置文件