package元素用来配置包。在Struts2框架中,包是一个独立的单位,通过name属性来唯一标识包。还可以通过extends属性让一个包继承另一个包,extends属性值就是被继承包的name属性值,继承包可以从被继承包那里继承到拦截器、Action等。
在Struts2框架中是通过包来管理action、result、interceptor、interceptor-stack等配置信息的。包属性如下:
属性 |
说明 |
name | 包名,作为其它包应用本包的标记 |
extends | 可选属性,设置本包继承其它包 |
namespace | 可选属性,设置包的命名空间 |
abstact | 可选属性,设置为抽象包 |
-extends
-namespace
示范:
<package name="caiwu" extends="struts-default" namespace="/caiwu"> </package>
Struts2框架通过Action对象来处理HTTP请求,该请求的URL地址对应的Action即配置在action元素中。
action元素属性
属性名称 |
功能描述 |
name | 请求的Action名称 |
class | 可选属性,Action处理类对应具体路径 |
method | 可选属性,指定Action中的方法名 |
converter | 可选属性,指定Action使用的类型转换器 |
示范:
<action name="list" class="com.clzhang.struts2.demo3.ListAction"> </action> <action name="listSalarySum" class="com.clzhang.struts2.demo3.ListAction" method="listSalarySum"> </action>
1.3 result元素
当调用Action方法处理结束返回后,下一步就是使用result元素来设置返回给浏览器的视图。配置result元素时常需要指定name和type两个属性。
result属性
属性名称 |
功能描述 |
name | 对应Action返回逻辑视图名称,默认为success |
type | 返回结果类型,默认为dispatcher |
Struts2支持的结果类型
结果类型 |
说明 |
dispatcher | 将请求转发(forward)到指定的JSP页面 |
redirect | 将请求重定向到指定的视图资源 |
chain | 处理Action链 |
freemarker | 指定Freemarker模板作为视图 |
httpheader | 控制特殊的HTTP行为 |
redirect-action | 直接跳转到其它Action |
stream | 向游览器返回一个InputStream(一般用于文件下载) |
velocity | 指定使用velocity模板作为视图 |
xslt | 用于XM/XSLT整合 |
plainText | 显示某个页面的原始代码 |
示范:
<action name="login" class="com.clzhang.struts2.demo1.LoginAction"> <result name="input">/struts2/demo1/login.jsp</result> <result name="error">/struts2/demo1/wrong.jsp</result> <result name="list" type="redirectAction"> <param name="idInList">${id}</param> <param name="actionName">listBook</param> </result> </action>
需要注意dispatcher和redirect的区别,也就是转发和重定向的区别,重定向会丢失所有的请求参数,而且会丢失Action处理结果。
在Struts2中提供了一个默认的struts.xml文件,但如果package、action、interceptors等配置比较多时,都放到一个struts.xml文件不太容易维护。因此,就需要将struts.xml文件分成多个配置文件,然后在struts.xml文件中使用<include>标签引用这些配置文件。
示范:
<include file="caiwu.xml"></include> <include file="cangku.xml"></include>
有很多时候一个<result>初很多<action>使用,这时可以使用<global-results>标签来定义全局的<result>。
示范:
<global-results> <result name="user">/struts2/demo3/user.jsp</result> <result name="sum">/struts2/demo3/sum.jsp</result> <result name="default">/struts2/demo3/default.jsp</result> </global-results>
如果在请求一个没有定义过的Action资源时,系统就会抛出404错误。这种错误不可避免,但这样的页面并不友好。我们可以使用<default-action-ref>来指定一个默认的Action,如果系统没有找到指定的Action,就会指定来调用这个默认的Action。
示范:
<default-action-ref name="acctionError"></default-action-ref> <action name="acctionError"> <result>/jsp/actionError.jsp</result> </action>
Struts2提供了包含多个处理逻辑的Action处理方式,即DMI(Dynamic Method Invocation,动态方法调用)。它是通过请求对象中的一个具体的方法来实现动态的操作。具体说,在请求Action的URL地址后加上请求方法字符串,与Action对象中的方法进行匹配。其中,Action对象名称和方法之间用“!“隔开。
更多内容参考:struts2:多业务方法的处理(动态调用,DMI)
示范:
<A href="list!listUser.action" target="_blank">3.2 通过URL叹号参数</A>
在实际的项目开发中,会出现多个Action定义的绝大部分都是相同的情况,这时就会产生大量冗余。对于这种情况,Struts2也给出了相应的解决方法,即使用通配符。
通配符 | 说明 |
* | 匹配0个或多个字符除了“/” |
** | 匹配0个或多个字符包含“/” |
\character | 转义字符,“\\”匹配“\”;“\*”匹配“*” |
通配符“*“通常用在<action>标签的name属性中,而在class、name属性及result元素中使用{n}的形式来代表前面第n个*所匹配的字符串,{0}来代表URL请求的整个Action字符串。
示范一:
<!-- 使用*通配符,第一个*表示调用方法,第二个*表示Action --> <action name="*_*" class="com.clzhang.struts2.action.{2}Action" method="{1}"> <result name="success">/{0}Suc.jsp</result> </action>
在上面代码中,当URL请求是/update_Login.action时,会调用LoginAction类中的update()方法,处理结束返回到update_LoginSuc.jsp。
示范二:
<!-- 不管调用哪个Action,默认返回名为Action名的JSP --> <action name="*_*"> <result>/{0}.jsp</result> </action>
上面代码中没有指定class属性,也没指定result元素的name,这样不管访问哪个Action都会返回与该Action名字相同的JSP页面。
在之前提到struts.properties配置文件的介绍中,我们曾经提到所有在struts.properties文件中定义的属性,都可以配置在struts.xml文件中。而在struts.xml中,是通过<constant>标签来进行配置的。
示范:
<constant name="struts.action.extension" value="action"></constant> <constant name="struts.ognl.allowStaticMethodAccess" value="true" /> <constant name="struts.ui.theme" value="simple"></constant> <constant name="struts.custom.i18n.resources" value="message"></constant> <constant name="struts.i18n.encoding" value="UTF-8"></constant>