详细介绍jsp中action的功能

开发 后端
本文介绍的是JSP中的action属性的功能,适合初学者阅读,希望对你有帮助,一起来看。

Action类是用户请求和业务逻辑之间的桥梁,每个Action充当客户的一项业务代理。在RequestProcessor类预处理请求时,在创建了Action的实例后,就调用自身的processActionPerform()方法,该方法在调用Action类的execute()。下面介绍jsp中action的功能。

1. 完整的action

 

  1. <action path="/aFullAction" 
  2. type="somePackage.someActionClass">  
  3. name="someForm" 
  4. input="someJSP.jsp" 
  5. <forward name="successful" path="someJSP.jsp"/>  
  6. <forward name="failed" path="someOtherJSP.jsp"/>  
  7. </action> 

 

首先,Struts的ActionServlet接收到一个请求,然后根据struts-config.xml的配置定位到相应的mapping(映射);接下来假如form的范围是request或在定义的范围中很难找到这个form,创建一个新的form实例;取得form实例以后,调用其reset ()方法,然后将表单中的参数放入form,假如validate属性不为false,调用validate()方法;假如validate()返回非空的ActionErrors,将会被转到input属性指定的URI,假如返回空的ActionErrors,那么执行Action的execute() 方法,根据返回的ActionForward确定目标URI。

这样做的效果是:execute()仅当validate()成功以后才执行;input属性指定的是个URI。

2. 仅有Form的action

 

  1. <action path="/aFormOnlyAction" 
  2. type="org.apache.struts.actions.ForwardAction" 
  3. name="someForm" 
  4. input="someJSP.jsp" 
  5. parameter="someOtherJSP.jsp" 
  6. /> 

 

首先,Struts会在定义的scope搜寻someForm,假如找到则重用,假如很难找到则新建一个实例;取得form实例以后,调用其reset()方法,然后将表单中的参数放入form,假如validate属性不为false,调用validate()方法;假如validate()返回非空的 ActionErrors,将会被转到input属性指定的URI,假如返回空的ActionErrors,那么转到parameter属性指定的目标 URI。

这样做的效果是:没有action类能够存放我们的业务逻辑,所以任何需要写入的逻辑都只能写到form的reset()或 validate()方法中。validate()的作用是验证和访问业务层。因为这里的action映射不包括forward(也没有意义),所以不能重定向,只能用默认的那个forward。这种仅有form的action能够用来处理数据获取并forward到另一个JSP来显示。

3. 仅有Action的action

 

  1. <action path="/anActionOnlyAction" 
  2. type="somePackage.someActionClass">  
  3. input="someJSP.jsp" 
  4. <forward name="successful" path="someJSP.jsp"/>  
  5. <forward name="failed" path="someOtherJSP.jsp"/>  
  6. </action> 

 

首先,ActionServlet接收到请求后,取得action类实例,调用execute()方法;然后根据返回的ActionForward在配置中找forward,forward到指定的URI或action。

这样做的效果是:没有form实例被传入execute()方法,于是execute()必须自己从请求中获取参数。Action能够被forward或重定向。这种action不能处理通过HTML FORM提交的请求,只能处理链接式的请求。

4. 仅有JSP的action

 

  1. <action path="/aJSPOnlyAction" 
  2. type="org.apache.struts.actions.ForwardAction" 
  3. parameter="someOtherJSP.jsp" 
  4. /> 

 

首先,ActionServlet接到请求后调用ForwardAction的execute()方法,execute()根据配置的parameter属性值来forward到那个URI。

这样做的效果是:没有任何form被实例化,比较现实的情形可能是form在request更高级别的范围中定义;或这个action被用作在应用程式编译好后充当系统参数,只需要更改这个配置文档而无需重新编译系统。

5. 两个action对应一个form

 

  1. <action path="/anAction" 
  2. type="somePackage.someActionClass">  
  3. name="someForm" 
  4. input="someJSP.jsp" 
  5. <forward name="successful" path="/anotherAction.do"/>  
  6. </action>  
  7. <action path="/anotherAction" 
  8. type="somePackage.someOtherActionClass">  
  9. name="someForm" 
  10. input="someOtherJSP.jsp" 
  11. <forward name="successful" path="someResultJSP.jsp"/>  
  12. </action> 

 

就每个单独的action来讲,处理上并没有和完整的action有什么实质的区分。这个组合模式能够被用来传递命令对象(form)。需要注意的是在后一个action中同样会调用form的reset()和validate()方法,因此我们必须确保form中的信息不被重写。

处理的方式大致分为两种:

a) 在request中放入一个指示器表明前一个action有意向后一个action传递form,从而在后一个action能够保留那个form中的值,这一方式只能在使用forward时使用。

b) 当使用redirect而不是forward时,能够把指示器放在session或更高的级别,在命令链的***一环将这个指示器清除。

 

  1. <action path="/anAction" 
  2. type="somePackage.someActionClass">  
  3. name="someForm" 
  4. input="someJSP.jsp" 
  5. <forward name="successful" path="/anotherAction.do" redirect="true"/>  
  6. </action>  
  7. <action path="/anotherAction" 
  8. type="somePackage.someOtherActionClass">"  
  9. name="someOtherForm" 
  10. input="someOtherJSP.jsp" 
  11. <forward name="successful" path="someResultJSP.jsp"/>  
  12. </action> 

 

这个组合方式跟前一种在流程上没有太大区分,只是我们现在对于两个action分别提供了form,于是代码看上去更加清楚。于是我们能够分别处理WEB应用程式的输入和输出。

值得注意的是,后一个action同样会尝试往form中写入那些参数,但是我们能够这样处理:

a) 在后一个form中使用另一套属性名;

b) 只提供getter而不提供setter。

大致的处理是这样:

前一个action接收输入、验证、然后将数据写入业务层或持久层,重定向到后一个action,后一个action手动的从业务层/持久层取出数据,写入form(通过其他方式),交给前台JSP显示。

这样做的好处是不必保留输入form中的值,因此能够使用redirect而不是forward。这样就降低了两个action之间的耦合度,同时也避免了不必要的重复提交。

【编辑推荐】

  1. JSP虚拟主机使用中的乱码问题
  2. JSP动态网站环境搭建应用中的详细步骤
  3. jsp速度优化七种方法
  4. 详细了解JSP中九个隐含对象
  5. 详细介绍JSP技术的两种架构模型
责任编辑:于铁 来源: 互联网
相关推荐

2009-03-17 16:18:51

JspActionStruts

2009-07-06 15:31:42

JSP Action

2011-07-08 16:54:39

JspCookies

2009-07-16 16:08:30

WebWork Act

2009-06-06 18:43:34

JSP Action

2009-07-03 11:21:43

Servlet和JSPJSP路径

2010-03-16 13:04:17

Python环境

2009-07-01 10:12:40

JSP环境配置JSP引擎

2009-09-02 09:44:01

JSP和JavaBea

2009-07-03 18:31:04

JSP表达式

2011-07-07 14:14:41

PHP模版

2011-06-07 11:14:51

JAVAJSP

2010-03-05 16:58:02

Android Mar

2012-08-08 17:13:43

Word 2013

2009-11-26 17:21:41

软路由upnp

2011-06-21 14:25:44

JavaScriptcookie

2011-06-15 13:07:10

JSP和JavaBea

2009-11-18 13:11:29

PHP核心

2011-06-16 14:49:39

HTML5

2011-07-21 15:44:33

Java内部类
点赞
收藏

51CTO技术栈公众号