Struts2的结果集的详细介绍及说明案例分析

来源:互联网 发布:黑鹰坠落真实事件知乎 编辑:程序博客网 时间:2024/06/05 10:04

Struts2的Action处理用户请求结束后,返回一个普通字符串——逻辑视图名,必须在struts.xml文件中完成逻辑视图和物理视图资源的映射,才可以让系统转到实际的视图资源。

简单的说,结果是告诉struts2框架,当Action处理结果时,系统下一步做什么。当Action返回一个普通字符串时,系统下一步将做什么。

Struts2通过在struts.xml文件中使用<result…/>元素来配置结果。根据<result…/>元素所在位置的不同,struts2提供了两种结果:

(1) 局部结果:将<result…/>作为<action…/>元素的子元素配置。

(2) 全局结果:将<result…/>作为<global-result…/>元素的子元素配置。

一、 下面我们首先来介绍一下局部结果,局部结果是通过在<action../>元素中指定<result…/>元素来配置的,一个<action…/>元素可以有多个<result…/>元素。这表示一个Action可以对应多个结果。

最典型的<result…/>配置如下:

[html] view plaincopyprint?
  1. <actionname="login"class="cn.csdn.hr.action.LoginAction"method="checkLogin">
  2. <!-- 为success的逻辑视图配置Result,type属性指定结果类型 -->
  3. <resultname="success"type="dispatcher">
  4. <!-- 指定该逻辑视图对应的实际视图资源 -->
  5. <paramname="location">./login.jsp</param>
  6. </result>
  7. </action>

对于上面使用了<param../>子元素配置结果的形式,其中<param../>元素的name属性可以有如下两个值:

(1) location:该参数指定了该逻辑视图对应的实际视图资源。

(2) parse:该参数指定是否允许在实际视图名字中使用OGNL表达式,该参数默认值为true。如果设置该参数值为false,则不允许在实际视图名中使用表达式。通常无需修改该属性值。因为通常无需指定parse参数的值。

除此之外,struts2还允许省略指定结果类型,即可简写成如下:

[html] view plaincopyprint?
  1. <actionname="login"class="cn.csdn.hr.action.LoginAction"method="checkLogin">
  2. <result>./login.jsp</result>
  3. </action>

二、struts2支持的处理结果类型

归纳一下来说,Struts2内建支持结果类型如下:

(1) chain结果类型:Action链式处理的结果类型。

(2) chart结果类型:用于整合JFreeChart的结果类型。

(3) dispatcher结果类型:用于FreeMarker整合的结果类型。

(4) httpheader结果类型:用于控制特殊的HTTP行为的结果类型。

(5) jasper结果类型:用于JasperReports整合的结果类型。

(6) jsf结果类型:用于与JSF整合的结果类型。

(7) redirect结果类型:用于直接跳转到其他URL的结果类型。

(8) redirect-action结果类型:用于制直接跳转到其他Action的结果类型。

(9) stream结果类型:用于向浏览器返回一个InputStream(一般用于文件下载)。

(10) tiles结果类型:用于与Tiles整合的结果类型。

(11) velocity结果类型:用于与Velicity整合的结果类型。

(12) xslt结果类型:用于与XML/XSLT整合的结果类型。

(13) plaintext结果类型:用于显示某个页面的原始代码的结果类型。

上面一共列出了14种类型,其中dispatcher结果类型是默认的类型,主要用于与JSP页面整合。

下面我将重点介绍dispatcher(默认值)、 redirect 、 redirectAction 、 plainText。常用的结果类型。

1、 plaintext结果类型

这个结果类型并不常用,因为它的作用太过局限:它主要用于显示实际视图资源的源代码。

以下是一个关于plaintext结果类型的小案例分析及其源代码以及显示效果:

对于如下简单的Action类:

[java] view plaincopyprint?
  1. publicclass LoginActionimplements Action{
  2. //用于封装请求参数的username属性
  3. private String username;
  4. //username属性的setter和getter方法
  5. public String getUsername() {
  6. return username;
  7. }
  8. publicvoid setUsername(String username) {
  9. this.username = username;
  10. }
  11. //处理用户请求的excute方法
  12. public String execute()throws Exception {
  13. return SUCCESS;
  14. }
  15. }

上面的Action类并为真正处理用户请求,它只是简单地返回了一个success的逻辑视图。在struts.xml文件中配置该Action,如果采用如下配置片段:

[html] view plaincopyprint?
  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <!DOCTYPE struts PUBLIC
  3. "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
  4. "http://struts.apache.org/dtds/struts-2.0.dtd">
  5. <struts>
  6. <!-- package 包的作用和java中的类包是非常类似的,它主要用于管理一组业务功能相关的action -->
  7. <packagename="test"extends="struts-default"namespace="/">
  8. <!-- 配置一个Action -->
  9. <actionname="login"class="cn.csdn.hr.action.LoginAction">
  10. <!-- 指定Result的类型为plaintext类型 -->
  11. <resulttype="plaintext">
  12. <!-- 指定实际的视图资源 -->
  13. <paramname="location">./welcome.jsp</param>
  14. <!-- 指定使用特定的编码集来处理页面代码 -->
  15. <paramname="charSet">utf-8</param>
  16. </result>
  17. </action>
  18. </package>
  19. </struts>

Jsp代码:

[html] view plaincopyprint?
  1. <%@ pagelanguage="java"import="java.util.*"pageEncoding="utf-8"%>
  2. <%@ tagliburi="/struts-tags"prefix="s"%>
  3. <%
  4. String path =request.getContextPath();
  5. String basePath =request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
  6. %>
  7. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  8. <html>
  9. <head>
  10. <basehref="<%=basePath%>">
  11. </head>
  12. <body>
  13. <s:propertyvalue="username"/>
  14. </body>
  15. </html>


如果将result的type指定为plaintext,那么将显示如下的效果:

这是将type类型指定为plaintext,显示的是视图资源的源代码。如果不指定类型,那么就是默认的类型dispatcher ,其默认类型,我输入的用户名是redarmy,点击提交按钮:显示效果如图:

2、 redirect结果类型:

(1)redirect结果类型与dispatcher结果类型相对,dispatcher结果类型是将请求Forward(转发)到指定的JSP资源;而redirect结果类型,是将请求Redirect(重定向)到指定的JSP视图资源。

(2)dispatcher结果类型与redirect结果类型的差别主要就是转发和重定向的差别;重定向会丢失所有的请求参数、请求属性——当然也丢失了Action的处理结果。

(3)使用redirect结果类型的效果是,系统将调用HttpServletResponse的sendRedirect(String)方法来重定向指定视图资源,这种重定向的效果就是重新产生一个请求,因此所有的请求参数、请求属性、Action实例和Action中的封装的属性全部丢失。

对于上面的应用,如果将struts.xml文件修改成如下形式;

[html] view plaincopyprint?
  1. <struts>
  2. <!-- package 包的作用和java中的类包是非常类似的,它主要用于管理一组业务功能相关的action -->
  3. <packagename="csdn"extends="struts-default"namespace="/">
  4. <!-- 配置一个Action -->
  5. <actionname="login"class="cn.csdn.hr.action.LoginAction">
  6. <!-- 指定Result的类型为redirect类型 -->
  7. <resulttype="redirect">./welcome.jsp</result>
  8. </action>
  9. </package>
  10. </struts>

上面的Result使用了redirect的结果类型,意思是:当Action处理用户请求结束后,系统将重新生成一个请求,直接转入welcome.jsp中。

效果图如下:

3、 redirect-action结果类型

这种结果类型与redirect类型非常相似,一样是重新生成一个全新的请求。

下面使用redirect-action结果类型的配置的实例:

[html] view plaincopyprint?
  1. <struts>
  2. <!-- package 包的作用和java中的类包是非常类似的,它主要用于管理一组业务功能相关的action -->
  3. <packagename="csdn"extends="struts-default"namespace="/">
  4. <!-- 配置一个Action -->
  5. <actionname="login"class="cn.csdn.hr.action.LoginAction">
  6. <!-- 指定Result的类型为plaintext类型 -->
  7. <resulttype="redirect-action">
  8. <!-- 指定重定向的actionName -->
  9. <paramname="actionName">aaa</param>
  10. <!-- 指定重定向的Action所在的命名空间 -->
  11. <paramname="names">/secure</param>
  12. </result>
  13. </action>
  14. </package>
  15. <packagename="csdn1"extends="struts-default"namespace="/">
  16. <!-- 配置一个Action -->
  17. <actionname="aaa"class="cn.csdn.hr.action.ChongAction">
  18. <!-- 指定Result的类型为plaintext类型 -->
  19. <result>./aaa.jsp</result>
  20. <!--配置一个redirect-action结果类型的result,重定向同一个命名 空间的Action -->
  21. <resulttype="redirect-action"name="error">error</result>
  22. </action>
  23. <actionname="error">
  24. <result>error.jsp</result>
  25. </action>
  26. </package>
  27. </struts>

使用redirect-action结果类型时,系统将重新生成一个新请求,只是该请求的URL不是一个具体的视图资源,而是一个Action,因此前一个Action处理结果,请求参数、请求属性都会丢失。

三、动态结果

动态结果的意思是指配置结果时,指定实际视图资源时使用了表达式语法,通过这种语法可以允许Action处理完用户请求后,动态转入实际的视图资源。

(1) 前面介绍Action配置时,可以通过在Action的name属性中使用通配符,在class或method属性中使用表达式。通过这种方式,我们可以根据请求来动态决定Action的处理类,以及动态决定处理方法。除此之外,我们也可以在配置<result../>元素时使用表达式语法,从而允许根据请求动态决定实际资源。

看下面的配置片段:

[html] view plaincopyprint?
  1. <actionname="login"class="cn.csdn.hr.action.LoginAction">
  2. <resultname="input">./input.jsp</result>
  3. <result>./success.jsp</result>
  4. </action>

当Action处理用户请求结束后,配置了两个结果:处理结果为input字符串时,系统将转到input.jsp页面:当处理结果为success字符串时,系统将转入success.jsp页面——这个视图资源时动态生成的。
四、请求参数决定结果

配置<result../>元素时,不仅可以使用${0}表达式形式来指定视图资源,还可以使用${属性名}的方式来指定视图资源。

下面我们通过一个案例还进一步了解它的使用:

(1) 首先定义出处理该请求的Action,它仅仅提供了一个属性来封装请求参数,并提供了一个参数才封装处理后的提示。下面是该Action类的代码。

[java] view plaincopyprint?
  1. import com.opensymphony.xwork2.Action;
  2. publicclass LoginActionimplements Action{
  3. //封装请求参数的target属性
  4. private String target;
  5. //封装处理结果提示的tip属性
  6. private String tip;
  7. //target属性和tip属性对应的getter和setter方法
  8. public String getTarget() {
  9. return target;
  10. }
  11. publicvoid setTarget(String target) {
  12. this.target = target;
  13. }
  14. public String getTip() {
  15. return tip;
  16. }
  17. publicvoid setTip(String tip) {
  18. this.tip = tip;
  19. }
  20. //处理用户请求的excute方法
  21. public String execute()throws Exception {
  22. setTip("恭喜您!您已成功转向!");
  23. return SUCCESS;
  24. }
  25. }

第二步我们来在struts.xml文件中配置该Action,配置文件如下:

[html] view plaincopyprint?
  1. <struts>
  2. <!-- package 包的作用和java中的类包是非常类似的,它主要用于管理一组业务功能相关的action -->
  3. <packagename="csdn"extends="struts-default"namespace="/">
  4. <!-- 配置一个Action -->
  5. <actionname="login"class="cn.csdn.hr.action.LoginAction">
  6. <resultname="success">./${target}.jsp</result>
  7. </action>
  8. </package>
  9. </struts>


这个程序就会实现跳转。

五、全局结果

前面已经提到了,struts2的<result../>元素配置,也可以放在<global-results../>元素中配置,当在<global-results../>元素中配置<result../>元素时,该<result../>元素配置了一个全局结果,全局结果的作用范围是对所有的Action都有效。

struts.xml配置文件如下:

[html] view plaincopyprint?
  1. <struts>
  2. <!-- package 包的作用和java中的类包是非常类似的,它主要用于管理一组业务功能相关的action -->
  3. <packagename="csdn"extends="struts-default"namespace="/">
  4. <!-- 定义全局结果 -->
  5. <global-results>
  6. <!-- 下面定义的结果对所有的Action都有效 -->
  7. <resultname="success">../${target}.jsp</result>
  8. </global-results>
  9. <!-- 配置处理用户请求的Action -->
  10. <actionname="login"class="cn.csdn.hr.action.LoginAction"/>
  11. </package>
  12. </struts>

上面的配置片段配置了一个Action,但在该Action内没有配置任何的结果——但这不会影响系统的运转,因为提供了一个名为success的全局结果,而这个全局结果的作用范围对所有的Action都有效。

如果一个Action里包含了与全局结果里同名的结果,则Action里的局部Action会覆盖全局Action。也就是说,当Action处理用户请求结束后,会首先在本Action里的局部结果里搜索逻辑视图对应的结果。只有在Action里的局部结果里找不到逻辑视图对应的结果,才会到全局结果里搜索。

原创粉丝点击