在struts.xml配置文件中遇到了param,有点迷糊,上网查了查……似乎明白些了

<action name="Log*" method="loginFrame{1}" class="member.loginIndeAct">
   <result>${tplPath}</result>
   <result name="logout" type="redirectAction">
    <param name="namespace">/jeecms</param>
    <param name="actionName">LoginFrameInput</param>
   </result>
  </action>

这里的action 是Log,他包含了登陆和退出,当系统在登录的时候就直接返回${tplPath}就可以了;在退出的时候需要返回到登陆页面,所以退出的时候是转发到 action的,转发到action肯定要告诉系统转发到那个action,该action的namespace是什么,名字是什么,就是通过param 该属性老告知struts2的;当然param还有其他用法,不过一般就用这个就差不多了,综上得出:

param标签主要用于为其他标签提供参数,例如bean和include标签。
param参数设置:
name:可选属性,指定设置参数名称
value:可选属性,指定参数的值
id:可选属性,指定该元素引用id

看到这,野猪似乎感觉清楚了许多,嘿嘿……

下面还搜到了一些信息,等野猪不是很清楚的时候再看看吧……

chain      
    用来处理Action链,被跳转的action中仍能获取上个页面的值,如request信息。      
    com.opensymphony.xwork2.ActionChainResult      
dispatcher      
    用来转向页面,通常处理JSP      
    org.apache.struts2.dispatcher.ServletDispatcherResult      
freemaker
      
    处理FreeMarker模板      
    org.apache.struts2.views.freemarker.FreemarkerResult      
httpheader      
    控制特殊HTTP行为的结果类型      
    org.apache.struts2.dispatcher.HttpHeaderResult   
stream      
    向浏览器发送InputSream对象,通常用来处理文件下载,还可用于返回AJAX数据      
    org.apache.struts2.dispatcher.StreamResult      
velocity      
    处理Velocity模板      
    org.apache.struts2.dispatcher.VelocityResult      
xslt      
    处理XML/XLST模板      
    org.apache.struts2.views.xslt.XSLTResult      
plainText      
    显示原始文件内容,例如文件源代码      
    org.apache.struts2.dispatcher.PlainTextResult      
plaintext      
    显示原始文件内容,例如文件源代码      
    org.apache.struts2.dispatcher.PlainTextResult 
redirect    
    重定向到一个URL ,被跳转的页面中丢失传递的信息,如request     
    org.apache.struts2.dispatcher.ServletRedirectResult      
redirectAction
      
    重定向到一个Action ,跳转的页面中丢失传递的信息,如request        
    org.apache.struts2.dispatcher.ServletActionRedirectResult      
redirect-action      
    重定向到一个Action ,跳转的页面中丢失传递的信息,如request        
    org.apache.struts2.dispatcher.ServletActionRedirectResult   
注:redirect与redirect-action区别

一、使用redirect需要后缀名 使用redirect-action不需要后缀名
二、type="redirect" 的值可以转到其它命名空间下的action,而redirect-action只能转到同一命名空下的 action,因此它可以省略.action的后缀直接写action的名称。
如:

<result name="success" type="redirect">viewTask.action</result>
<result name="success" type="redirect-action">viewTask</result>

附:redirect-action 传递参数

 
  1. <action name="enterpreinfo" class="preinfoBusinessAction"    method="enterPreinfoSub">  
  2.   <result name="success" type="redirect-action">  
  3.      showpreinfo?preinfo.order_number=${preinfo.order_number}&amp;preinfo.company_name=${preinfo.company_name}   
  4.   </result>  
  5.  <result name="error" type="redirect">  
  6.     <param name="location">/error.jsp</param>  
  7.  </result>  
  8. </action>  

   因为使用了redirect-action,所以要注意不能将 showpreinf?preinfo.order_number=${preinfo.order_number}写成 showpreinf.action?preinfo.order_number=${preinfo.order_number}

其中${}为EL表达式,获取action:enterpreinfo中属性的值在这个配置文件里,多个参数的连接符使用了"&amp;",但XML的语法规范,应该使用"&amp;"代替"&",原理和HTML中的转义相同,开始没有注意,在struts分析配置文件时,总是报出这样的错误:

json   一般很容易忽略的一个地方(在EXT中非常有用)
示例
 
  
  1. <package name="struts2" extends="json-default" namespace="/">  
  2.         <action name="login" class="loginAction" method="login">  
  3.             <result type="json">  
  4.                 <param name="includeProperties">success,result</param>                
  5.             </result>               
  6.         </action>  
  7.         <action name="main" class="loginAction" method="main">  
  8.             <result name="main">/index.jsp</result>           
  9.         </action>   
  10.     </package>  
<package name="struts2" extends="json-default" namespace="/"> <action name="login" class="loginAction" method="login"> <result type="json"> <param name="includeProperties">success,result</param> </result> </action> <action name="main" class="loginAction" method="main"> <result name="main">/index.jsp</result> </action> </package>
 
  
  1. private boolean success  = true;  
  2. private String result = "main.action";  
  3. //getter和setter方法略  
private boolean success = true; private String result = "main.action"; //getter和setter方法略
以上的success和result互相对应到了
 
  
  1. <param name="includeProperties">success,result</param>    
<param name="includeProperties">success,result</param>
struts2会根据其设置的值匹配跳转
 
  
对于json一般情况下很少用到,但是在处理ext的时候会用到这个属性类型,这个地方也是经常被忽略的。

最后感觉还是应该查一下文档给野猪看看,嘿嘿:

Redirect Action Result

  • actionName (default) - the name of the action that will be redirect to
  • namespace - used to determine which namespace the action is in that we're redirecting to . If namespace is null, this defaults to the current namespace
<package name="public" extends="struts-default">
    <action name="login" class="...">
        <!-- Redirect to another namespace -->
        <result type="redirect-action">
            <param name="actionName">dashboard</param>
            <param name="namespace">/secure</param>
        </result>
    </action>
</package>

<package name="secure" extends="struts-default" namespace="/secure">
    <-- Redirect to an action in the same namespace -->
    <action name="dashboard" class="...">
        <result>dashboard.jsp</result>
        <result name="error" type="redirect-action">error</result>
    </action>

    <action name="error" class="...">
        <result>error.jsp</result>
    </action>
</package>

<package name="passingRequestParameters" extends="struts-default" namespace="/passingRequestParameters">
   <-- Pass parameters (reportType, width and height) -->
   <!--
   The redirect-action url generated will be :
   /genReport/generateReport.action?reportType=pie&width=100&height=100
   -->
   <action name="gatherReportInfo" class="...">
      <result name="showReportResult" type="redirect-action">
         <param name="actionName">generateReport</param>
         <param name="namespace">/genReport</param>
         <param name="reportType">pie</param>
         <param name="width">100</param>
         <param name="height">100</param>
      </result>
   </action>
</package>

Redirect Result

  • location (default) - the location to go to after execution.
  • parse - true by default. If set to false, the location param will not be parsed for Ognl expressions.
  • <result name="success" type="redirect">
      <param name="location">foo.jsp</param>
      <param name="parse">false</param>
    </result>
    
    <package name="passingRequestParameters" extends="struts-default" namespace="/passingRequestParameters">
       <-- Pass parameters (reportType, width and height) -->
       <!--
       The redirect-action url generated will be :
       /genReport/generateReport.jsp?reportType=pie&width=100&height=100
       -->
       <action name="gatherReportInfo" class="...">
          <result name="showReportResult" type="redirect">
             <param name="location">generateReport.jsp</param>
             <param name="namespace">/genReport</param>
             <param name="reportType">pie</param>
             <param name="width">100</param>
             <param name="height">100</param>
          </result>
       </action>
    </package>

这下感觉怎么样了?野猪!多看看文档!

最后,又看了一眼result的默认参数:

<result name="success" type="dispatcher">
    <param name="location">/ThankYou.jsp</param>
</result>

呵呵……这还比较满意!吃饭去!野猪!