一.action配置中的默认值
如果在项目开发当用户请求一个路径时,我们想直接向该路径转发到一个前台页面,可以通过如下配置完成:
<package name="bdyc" namespace="/test" extends="struts-default"> <action name="register" > <result>/WEB-INF/page/register.jsp</result> </action> </package> |
1.如果没有为action指定class,默认的class是ActionSupport。
2.如果没有为action指定method,默认执行action中的execute方法。
3.如果没有为result指定name属性,默认值为success。
等价于:
<package name="bdyc" namespace="/test" extends="struts-default"> <action name="register" class="com.opensymphony.xwork2.ActionSupport" method="execute" > <result name="success">/WEB-INF/page/register.jsp</result> </action> </package> |
二.action中result的各种转发类型
struts2提供了多种结果类型(result的type),常用的类型有:
rdispatcher(默认值):转发到jsp(默认type,所以没有写)
chain:转发到action
redirect:重定向到jsp
重定向的过程中赋的值消失
redirectAction:重定向到action
结果类型为redirectAction的例子:
重定向到同一个包中的action配置:
<result type="redirectAction">add</result> |
重定向到别的namespace中的action配置:
<result type="redirectAction"> <param name="actionName">action名称</param> <param name="namespace">/命名空间</param> </result> |
三.指定struts2的请求后缀
前面我们都是默认使用.action后缀访问Action。其实默认后缀是可以通过常量”struts.action.extension“进行修改的,例如:我们可以配置Struts 2只处理以.action为后缀的请求路径:
这个属性一般不去设置,设置了以后访问时地址栏就必须写后缀。
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <constant name="struts.action.extension" value="action"/> </struts> |
如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。如:
<constant name="struts.action.extension" value="action,do"/> |
四.常量定义:
常量可以在struts.xml或struts.properties中配置,建议在struts.xml中配置,两种配置方式如下:
在struts.xml文件中配置常量:
<struts>
<constant name="struts.action.extension" value="do"/>
</struts>
在struts.properties中配置常量:
struts.action.extension=do
因为常量可以在下面多个配置文件中进行定义,所以我们需要了解struts2加载常量的搜索顺序:
struts-default.xml
struts-plugin.xml
struts.xml
struts.properties
web.xml
如果在多个文件中配置了同一个常量,则后一个文件中配置的常量值会覆盖前面文件中配置的常量值.
常用的常量介绍
1、 指定默认编码集,作用于HttpServletRequest的setCharacterEncoding方法 和freemarker 、velocity的输出
<constant name="struts.i18n.encoding" value="UTF-8"/>
2、该属性指定需要Struts 2处理的请求后缀, 该属性的默认值是action,即所有匹配 *.action的请求都由Struts2处理。 如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。
<constant name="struts.action.extension" value="action"/>
3、 设置浏览器是否缓存静态内容,默认值为true(生产环境下使用),开发阶段最好关闭
<constant name="struts.serve.static.browserCache" value="false"/>
4、当struts的配置文件修改后,系统是否自动重新加载该文件,默认值为false (生产环境 下使用),开发阶段最好打开
<constant name="struts.configuration.xml.reload" value="true"/>
5、开发模式下使用,这样可以打印出更详细的错误信息 <constant name="struts.devMode" value="true" />
6、 默认的视图主题 <constant name="struts.ui.theme" value="simple" />
7、 与spring集成时,指定由spring负责action对象的创建 <constant name="struts.objectFactory" value="spring" />
8、该属性设置Struts 2是否支持动态方法调用,该属性的默认值是true。 如果需要关闭动态方法调用,则可设置该属性为false。
<constant name="struts.enable.DynamicMethodInvocation" value="false"/>
9、上传文件的大小限制 <constant name="struts.multipart.maxSize" value=“10701096"/>
|
五.struts处理流程
StrutsPrepareAndExecuteFilter是struts2框架的核心控制器,它负责拦截由<url-pattern>/*</url-pattern>指定的所有用户请求,当用户请求到达时,该Filter会过滤用户请求。默认情况下,如果用户请求的路径不带后缀或是后缀是action,这时请求将被struts2框架处理,否则struts2将略过该请求。当请求转入struts2处理时会先经过一些列的拦截器,然后到action。与struts1不同,struts2对用户的每一个请求都会创建一个action(多例),所以struts2是线程安全的。
六.访问action的几种常用方式
在配置文件的action中指定method,在访问的时候通过直接访问action名称即可访问到对应的方法。
1、指定method
例如:
<package name="user" namespace="/user" extends="struts-default"> <!-- 访问添加页面方法 --> <action name="addUI" class="com.bdyc.action.UserAction" method="addUI" > <result name="addUI">/WEB-INF/user/add.jsp</result> </action> <!-- 访问修改页面方法 --> <action name="updateUI" class="com.bdyc.action.UserAction" method="updateUI" > <result name="updateUI">/WEB-INF/user/update.jsp</result> </action> </package> |
2、动态方法调用
在配置文件的action中不指定method,而是在访问的时候通过actionname!methodname这种方式来访问,前提是struts.enable.DynamicMethodInvocation要设置为true。
例如:
<package name="user" namespace="/user" extends="struts-default"> <action name="userAction" class="com.bdyc.action.UserAction" > <result name="addUI">/WEB-INF/user/add.jsp</result> <result name="updateUI">/WEB-INF/user/update.jsp</result> </action> </package> |
假设com.bdyc.action.UserAction类中有addUI()和updateUI()两个方法,可以使用"/user/userAction!addUI"来访问addUI()方法。
3、使用通配符的定义action(适合于:多个方法执行完毕最终都去一个页面)
使用通配符*定义action,可以有效的减小配置文件的规模。下面就是一个简单的例子,和上面动态方法调用中的配置文件类似:
<package name="user" namespace="/user" extends="struts-default"> <action name="userAction_*" class="com.bdyc.action.UserAction" method="{1}"> <result name="addUI">/WEB-INF/user/add.jsp</result> <result name="updateUI">/WEB-INF/user/update.jsp</result> </action> </package> |
假设com.bdyc.action.UserAction类中有addUI()和updateUI()两个方法,这样定义后,就可以使用”/user/userAction_addUI“来访问addUI()方法。