struts2中result参数详解

1.result中name的参数:

SUCCESS:Action正确的执行完成,返回相应的视图,success是name属性的默认值;
 
NONE:表示Action正确的执行完成,但并不返回任何视图;

ERROR:表示Action执行失败,返回到错误处理视图;
 
INPUT:Action的执行,需要从前端界面获取参数,INPUT就是代表这个参数输入的界面,一般在应用中,会对这些参数进行验证,如果验证没有通过,将自动返回到该视图;
 
LOGIN:Action因为用户没有登陆的原因没有正确执行,将返回该登陆视图,要求用户进行登陆验证。

2.result中type的参数:

dispatcher:(默认配置,用来转向页面,通常处理JSP,org.apache.struts2.dispatcher.ServletDispatcherResult)请求

转发,底层调用RequestDispatcher的forward()或include()方法,dispatcher是type属性的默认值,通常用于转向一个

JSP,localtion指定JSP的位置,parse如果为false表示location的值不会被当作OGNL解析,默认为true;(服务器跳

转)
 
redirect:(重定向到一个URL ,org.apache.struts2.dispatcher.ServletRedirectResult )重定向,新页面无法显示Action

中的数据,因为底层调用response.sendRedirect("")方法,无法共享请求范围内的数据,参数与dispatcher用法相同;

(客户端跳转)

chain:(用来处理Action链 ,com.opensymphony.xwork2.ActionChainResult)将action的带着原来的状态请求转发到新

的action,两个action共享一个ActionContext,actionName指定转向的新的Action的名字,method指定转向哪个方

法,namespace指定新的Action的名称空间,不写表示与原Action在相同的名称空间;skipActions指定一个使用 , 连接

的Action的name组成的集合,一般不建议使用这种类型的结果; (Action转发,forward方式,服务器跳转到Action)

redirect-action:(重定向到一个Action,org.apache.struts2.dispatcher.ServletActionRedirectResult )重定向到另一个

Action,参数与chain用法相同,允许将原Action中的属性指定新名称带入新Action中,可以在Result标签中添加

<param name=”b”>${a} </param>,这表示原Action中的变量a的值被转给b,下一个Action可以在值栈中使用b来操

作,注意如果值是中文,需要做一些编码处理,因为Tomcat默认是不支持URL直接传递中文的!(客户端跳转到

Action)

velocity:(处理Velocity模板,org.apache.struts2.dispatcher.VelocityResult )使用velocity模板输出结果,location指定

模板的位置(*.vm),parse如果为false,location不被OGNL解析,默认为true;
 
xslt:(处理XML/XLST模板,org.apache.struts2.views.xslt.XSLTResult)使用XSLT将结果转换为xml输出,location指定

*.xslt文件的位置,parse如果为false,location不被OGNL解析,默认为true,matchingPattern指定想要的元素模式,

excludePattern指定拒绝的元素模式,支持正则表达式,默认为接受所有元素;
 
httpheader:(控制特殊HTTP行为的结果类型,org.apache.struts2.dispatcher.HttpHeaderResult )根据值栈返回自定义

的HttpHeader,status指定响应状态(就是指response.sendError(int i)重定向到500等服务器的状态页),parse如果

为false,header的值不会被OGNL解析,headers,加入到header中的值,例如:

<param name=”headers.a”>HelloWorld </param>,可以加多个,这些键-值组成HashMap;

freemaker:(处理FreeMarker模板,org.apache.struts2.views.freemarker.FreemarkerResult )用freemaker模板引擎呈

现视图,location指定模板(*.ftl)的位置,parse如果为false,location的值不会被OGNL解析,contentType指定以何

中类型解析,默认为text/html;
 
stream:(向浏览器发送InputSream对象,通常用来处理文件下载,还可用于返回AJAX数

据, org.apache.struts2.dispatcher.StreamResult )直接向响应中发送原始数据,通常在用户下载时使用,contentType

指定流的类型,默认为text/plain,contentLength以byte计算流的长度,contentDisposition指定文件的位置,通常为

filename=”文件的位置”,input指定InputStream的名字,例如:imageStream,bufferSize指定缓冲区大小,默认为

1024字节;
 
plaintext:(显示原始文件内容,例如文件源代码,org.apache.struts2.dispatcher.PlainTextResult )以原始文本显示JSP

或者HTML,location指定文件的位置,charSet指定字符集;(打代码原样输出)

3.dispatcher ,redirect,chain,redirect-action,plaintext参数详解

dispatcher 为默认跳转类型,用于返回一个视图资源(如:jsp)

Xml代码 :

[html] view plain copy

  1. <span style="font-size:18px;"><result name="success">/main.jsp</result></span>

以上写法使用了两个默认,其完整的写法为:

[html] view plain copy

  1. <span style="font-size:18px;"><result name="success"type="dispatcher">
  2. <paramnameparamname="location">/maini.jsp</param>
  3. </result></span>

用于页面转发,页面跳转过程一直是同一个线程,Action中的数据一直保存着。

location只能是页面,不能是另一个action(可用type="chain"解决)。
 
redirect 类型用于重定向到一个页面,另一个action或一个网址。

Xml代码:

[html] view plain copy

  1. <span style="font-size:18px;"><result name="success"type="redirect">aaa.jsp</result>
  2. <result name="success"type="redirect">bbb.action</result>
  3. <result name="success"type="redirect">www.baidu.com</result></span>

缺点:redirect把一个http返回码(SUCCESS)以及返回的页面位置一起重新发给web服务器,容纳后由web服务器

产生一个新的HTTP请求,就会产生一个新的线程,保存在原来Action执行的线程中的数据就无法访问。

所以,result需要包含Action的数据,那么redirect不是一个可行的办法。因为新的HTTP请求时在Servlet容器的新的线

程中处理的,ActionContext中的所有状态都不会存在。

处理方法:

(方法一):

[html] view plain copy

  1. <span style="font-size:18px;"><result name="topic"type="redirect">/topicAction!findTopics.do?topicId=${topicId}</result></span>

(方法二):

[html] view plain copy

  1. <span style="font-size:18px;"><result name="topic"type="redirect-action">
  2. <param name="actionName">findTopics</param>
  3. <param name="topicId">${topicId}</param>
  4. </result></span>

redirect-action结果类型使用ActionMapperFactory提供的ActionMapper来重定向请求到另外一个action

Xml代码:

[html] view plain copy

  1. <span style="font-size:18px;"><result name="err"type="redirect-action">
  2. <param name="actionName">重定向的Action名</param>
  3. <param name="namespace">重定向Action所在的名字空间</param>
  4. </result></span>

redirect和redirect-action两种结果类型在使用上其实并没有什么区别,只是写法不同而已。

chain 用于把相关的几个action连接起来,共同完成一个功能。

Xml代码:

[html] view plain copy

  1. <action name="step1"class="test.Step1Action">
  2. <result name="success"type="chain">step2.action</result>
  3. </action>
  4. <action name="step2"class="test.Step2Action">
  5. <result name="success">finish.jsp</result>
  6. </action>

处于chain中的action属于同一个http请求,共享一个ActionContext
 
plaintextj 结果类型用于直接在页面上显示源代码

Xml代码:

[html] view plain copy

  1. <result name="err"type="plaintext">
  2. <param name="location">具体的位置</param>
  3. <param name="charSet">字符规范(如GBK)</param>
  4. </result>

在strutx.xml配置文件中,我们可以使用${nextAction}来引用到Action中的属性,通过${nextAction}表示的内容来动态的

返回结果,例如:

[html] view plain copy

    1. <action name="fragment" class="FragmentAction">
    2. <result name="next" type="redirect-action">${nextAction}</result>
    3. </action>
时间: 2024-12-25 21:47:35

struts2中result参数详解的相关文章

【转】Struts2中的OGNL详解 (1)

 转载声明:菰☆淚 - Struts2中的OGNL详解 首先了解下OGNL的概念: OGNL是Object-Graph Navigation Language的缩写,全称为对象图导航语言,是一种功能强大的表达式语言,它通过简单一致的语法,可以任意存取对象的属性或者调用对象的方法,能够遍历整个对象的结构图,实现对象属性类型的转换等功能. 此外,还得先需弄懂OGNL的一些知识: 1.OGNL表达式的计算是围绕OGNL上下文进行的. OGNL上下文实际上就是一个Map对象,由ognl.OgnlCont

【转】Struts2中的OGNL详解 (2)

转载声明:菰☆淚 -Struts2中的OGNL详解 总结OGNL的使用方法: 访问属性 名字属性获取:<s:property value="user.username"/><br> 地址属性获取:<s:property value="user.address.addr"/><br> 访问方法 调用值栈中对象的普通方法:<s:property value="user.get()"/><

struts2中ognl标签详解

<body> <s:set name="age" value="61" /> <!-- if elseif else 参数test:决定标志里的内容是否显示的表达式,类型boolean 注:else标志没有这个参数 --> <h3>if语句</h3> <s:if test="{age>60}"> 老年人 </s:if> <s:elseif test=&

Struts2中的OGNL详解

首先了解下OGNL的概念: OGNL是Object-Graph Navigation Language的缩写,全称为对象图导航语言,是一种功能强大的表达式语言,它通过简单一致的语法,可以任意存取对象的属性或者调用对象的方法,能够遍历整个对象的结构图,实现对象属性类型的转换等功能. 此外,还得先需弄懂OGNL的一些知识: 1.OGNL表达式的计算是围绕OGNL上下文进行的. OGNL上下文实际上就是一个Map对象,由ognl.OgnlContext类表示.它里面可以存放很多个JavaBean对象.

Struts2中的OGNL详解 《转》

首先了解下OGNL的概念: OGNL是Object-Graph Navigation Language的缩写,全称为对象图导航语言,是一种功能强大的表达式语言,它通过简单一致的语法,可以任意存取对象的属性或者调用对象的方法,能够遍历整个对象的结构图,实现对象属性类型的转换等功能. 此外,还得先需弄懂OGNL的一些知识: 1.OGNL表达式的计算是围绕OGNL上下文进行的. OGNL上下文实际上就是一个Map对象,由ognl.OgnlContext类表示.它里面可以存放很多个JavaBean对象.

droid AVD创建及设置中各参数详解

设置AVD时有些参数比较模糊,特地找了篇文章,大家参考下! 本文根据如下的模拟器安装做一些解释: Name:自定义虚拟的名称,不能有空格或者其他非法字符,否则不能创建,即Creat AVD不能高亮点击.Target:选择要运行的android 版本(也可理解为内核?),此处有两个版本,取决于你在最初时下载的选择,个人理解这两个同样为2.2版本差异在从名称上不难理解,一个是优化后的内核包,一个是google原生态的,当然这两个都是Google原版本,未被做过其他改动,通过查看img以及表现在系统启

directive中的参数详解

restrictE: 表示该directive仅能以element方式使用,即:<my-dialog></my-dialog>A: 表示该directive仅能以attribute方式使用,即:<div my-dialog></div>EA: 表示该directive既能以element方式使用,也能以attribute方式使用 transclude你的directive可能接受页面上的其他html内容时才会用到,建议你先去掉该参数.有些高阶了. scope

BLAST+中makeblastdb参数详解

以后打算工作中用到的相关BLAST操作全部用BLAST+来完成 与以前的Blast相以,我们还是从格式化数据库到比对开始 一般我们是有一个fasta文件用来格式化数据库,以前的命令是formatdb,现在是makeblastdb 一般用到的格式如下: makeblastdb -in input_file -dbtype molecule_type -title database_title -parse_seqids -out database_name -logfile File_Name -

JQuery中$.ajax()方法参数详解

url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. type: 要求为String类型的参数,请求方式(post或get)默认为get.注意其他http请求方法,例如put和 delete也可以使用,但仅部分浏览器支持. timeout: 要求为Number类型的参数,设置请求超时时间(毫秒).此设置将覆盖$.ajaxSetup()方法的全局设 置. async:要求为Boolean类型的参数,默认设置为true,所有请求均为异步请求. 如果需要发送同步请求,请将此选项