一口一口吃掉Struts(八)——四种forward

Struts设置转向信息的时候,需要用到Forward。我们有四种不同的处理方式:

 

  1.   <!--方式一、 全局转向信息,所有Action公用 -->  
  2. <global-forwards>  
  3.     <forward name="error" path="/mustLogin.jsp" />  
  4. </global-forwards>  
  5.   
  6. <action-mappings>  
  7.      <!--方式二、 直接转向,不牵扯到action,完全交给Struts控制-->  
  8.     <action path="/showLoginWithForward" forward="/index.jsp" />  
  9.   
  10.        <!--方式三、 利用Struts提供的ForwardAction转向,转向信息放在parameter中 -->  
  11.     <action path="/showLoginWithForwardAction" type="org.apache.struts.actions.ForwardAction"  
  12.         parameter="/index.jsp" />  
  13.           
  14.        <!--方式四、forward作为action子元素完成转向 -->  
  15.     <action path="/showLoginWithChildForward" type="com.jialin.struts.TestAction">  
  16.         <forward name="success" path="/index.jsp"></forward>  
  17.     </action>  
  18.       
  19. </action-mappings>  

 

这几种方式有什么区别?

1、方式一的forward的是全局共享的,所有Action都可以使用,而其余三种方式只有相应的action才能使用

2、方式二仅仅起到一个转向的作用,完全由struts控制,很方便,但是我们不方便加入自定义的操作,除非重写struts框架中的类的方法。

3、方法三和方法四,最大的区别在方式三不用我们自己写action了,它用的是Struts已经写好的action。需要注意的是,无论ActionForward还是我们自定义的action都是继承自Struts的核心类Action

那么,既然有自定义的action,为什么需要ForwardAction?
*目的是发出一个RequestDispatcher转发
*ForwardAction的绝大多数使用是作为Action的占位符
*ForwardAction创建一个请求分派器,并根据ActionMapping提供的上下文相关的URI转发控制
*许多 Struts 开发人员避免从一个页面直接连接到其他地方而是通过Action 或者 ActionForward来传递控制。这保证了工作流在Struts 配置的控制之下,在这里可以进行集中管理。
*然而,许多页面并不需要特殊的预处理(至少还不需要)。如果为这些页面创建ActionMapping,你可以使用ForwardAction,来仅进行路由控制。如果以后,需求改变,又需要进行预处理,你可以改变mapping 来为那个页面引用到一个Action。因为链接是引用到mapping, 而不是Action类, 所以你可以修改Action类而不用改变链接。

 

4、如果同时存在一个action标签同时存在forward属性,又存在forward子元素,那么前者优先,不会执行到自定义action的exceute方法。

在Struts核心类,RequestProcessor的方法process中,我们看到

  // Process a forward or include specified by this mapping         if (!processForward(request, response, mapping)) {             return;         }

如果存在forward的属性,就直接返回了,不再向下执行了,不会调到我们自定义action的exceute方法。

我们如果要做一些自己的事,就必须用forward的子元素的方式,而不能用forward属性的方式。

posted @ 2013-10-15 15:07  huidaoli  阅读(158)  评论(0编辑  收藏  举报