1.Struts2通配符映射機(jī)制
一個(gè) Web 應(yīng)用可能有成百上千個(gè) action 聲明. 可以利用 struts 提供的通配符映射機(jī)制把多個(gè)彼此相似的映射關(guān)系簡(jiǎn)化為一個(gè)映射關(guān)系
1.1 通配符映射規(guī)則
- 若找到多個(gè)匹配, 沒(méi)有通配符的那個(gè)將勝出
- 若指定的動(dòng)作不存在, Struts 將會(huì)嘗試把這個(gè) URI 與任何一個(gè)包含著通配符 的動(dòng)作名及進(jìn)行匹配
- 若 Struts 找到的帶有通配符的匹配不止一個(gè), 最后一個(gè)匹配將勝出
- 被通配符匹配到的 URI 字符串的子串可以用 {1}, {2} 來(lái)引用. {1} 匹配第一個(gè)子串, {2} 匹配第二個(gè)子串…
- {0} 匹配整個(gè) URI
- 通配符可以匹配零個(gè)或多個(gè)字符, 但不包括 / 字符. 如果想把 / 字符包括在內(nèi), 需要使用 **. 如果需要對(duì)某個(gè)字符進(jìn)行轉(zhuǎn)義, 需要使用 .
1.2 通配符案例
案例一: 多個(gè)路徑訪問(wèn)同一個(gè)Action的同一個(gè)方法
pattern.jsp映射路徑
所有的路徑都是以xxxx_save.action模式出現(xiàn)的! 這三個(gè)路徑需要訪問(wèn)同一個(gè)Action的 save()方法,如果沒(méi)有通配符配置,那么就需要重復(fù)配置三個(gè)Action。
通配符映射規(guī)則:
案例二: 不同的路徑執(zhí)行不同Action的相同方法
pattern.jsp映射路徑
所有的路徑都是以Action類(lèi)名XxxAction_save開(kāi)頭的伙狐。
普通映射規(guī)則
使用通配符簡(jiǎn)化配置
使用*先將請(qǐng)求的路徑匹配上,然后根據(jù)匹配的結(jié)果值傳遞給{1}中的參數(shù)涮毫。
案例三: 不同的路徑執(zhí)行同一個(gè)Action中不同的方法CRUD
pattern.jsp映射路徑
通配符映射規(guī)則:
2.Struts2動(dòng)態(tài)方法調(diào)用
動(dòng)態(tài)方法調(diào)用: 通過(guò) url 動(dòng)態(tài)調(diào)用 Action 中的方法
如果Action中存在多個(gè)方法時(shí),我們可以使用!+方法名調(diào)用指定方法
默認(rèn)情況下, Struts 的動(dòng)態(tài)方法調(diào)用處于激活狀態(tài), 若想禁用該功能, 則可以在 struts.xml 文件中添加如下 constant 元素:
<constant name="struts.enable.DynamicMethodInvocation" value="false"/>
實(shí)現(xiàn)
注意:如果開(kāi)發(fā)者手工的將動(dòng)態(tài)方法調(diào)用設(shè)置為不可用,那么使用!直接報(bào)錯(cuò)贷屎。
3.Struts2全局結(jié)果
當(dāng)多個(gè)action中都使用到了相同result罢防,為了避免result的重復(fù),這時(shí)我們
應(yīng)該把result定義為全局結(jié)果唉侄。
實(shí)現(xiàn)
注意:
如果全局和局部有同名的result咒吐,那么局部會(huì)覆蓋全局的result。
同一個(gè)應(yīng)用中每次請(qǐng)求Struts2框架都會(huì)創(chuàng)建一個(gè)新的Action實(shí)例属划。
( 開(kāi)發(fā)者可以定義構(gòu)造函數(shù)輸出來(lái)測(cè)試 )
4. Struts2的resultType
resultType可以在配置文件struts-default.xml里看到恬叹,如下
<result-types>
<result-type name="chain" class="com.opensymphony.xwork2.ActionChainResult"/>
<result-type name="dispatcher" class="org.apache.struts2.dispatcher.ServletDispatcherResult" default="true"/>
<result-type name="freemarker" class="org.apache.struts2.views.freemarker.FreemarkerResult"/>
<result-type name="httpheader" class="org.apache.struts2.dispatcher.HttpHeaderResult"/>
<result-type name="redirect" class="org.apache.struts2.dispatcher.ServletRedirectResult"/>
<result-type name="redirectAction" class="org.apache.struts2.dispatcher.ServletActionRedirectResult"/>
<result-type name="stream" class="org.apache.struts2.dispatcher.StreamResult"/>
<result-type name="velocity" class="org.apache.struts2.dispatcher.VelocityResult"/>
<result-type name="xslt" class="org.apache.struts2.views.xslt.XSLTResult"/>
<result-type name="plainText" class="org.apache.struts2.dispatcher.PlainTextResult" />
</result-types>
4.1 resultType之dispatcher
默認(rèn)的結(jié)果類(lèi)型,以下兩種情況等價(jià):
參見(jiàn)dispatcher對(duì)應(yīng)的class: ServletDispatcherResult API 推薦寫(xiě)法如下:
**注意: ** dispatcher只是請(qǐng)求轉(zhuǎn)發(fā)同眯,不能轉(zhuǎn)發(fā)到外部的資源绽昼,只能在本應(yīng)用中轉(zhuǎn)發(fā), 如果要跨應(yīng)用訪問(wèn)資源须蜗,需要使用重定向绪励。
4.2 resultType之redirect
參見(jiàn)redirect對(duì)應(yīng)的class: ServletRedirectResult API 推薦寫(xiě)法如下:
location: 指定跳轉(zhuǎn)的路徑,/開(kāi)頭默認(rèn)添加應(yīng)用名唠粥。
parse : 指定是否把 location 參數(shù)的值視為一個(gè) OGNL 表達(dá)式來(lái)解釋. 默認(rèn)值為 true
4.3 resultType之redirectAction
參見(jiàn)redirectAction對(duì)應(yīng)的class: ServletActionRedirectResult API 推薦寫(xiě)法如下:
actionName: 指定跳轉(zhuǎn)的Action的名字, 該Action已經(jīng)定義疏魏。
namespace: 指定該Action所在的命名空間。