JBuilder2005 Struts深度体验之概述

2008-02-23 07:49:16来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

  Struts是基于Model 2实现的技术框架,Model 2是经典的MVC(Model,View,Control)模型的Web应用变体,这个改变主要由于HTTP协议的无状态性引起的。Model 2的目的和MVC一样,也是利用控制器来分离模型和视图,达到不同层间松散耦合的效果,提高系统灵活性、复用性和可维护性。在多数情况下,你可以将Model 2与MVC等同起来。

  图 1表示一个基于Java技术典型的MVC网络应用,从中可以看出MVC中的各个部分对应于J2EE哪些实现技术。


图 1 MVC和J2EE技术
  在利用Model 2之前,我们把所有的表示逻辑和业务逻辑都集中在一起(如我们前两个专题中的login.jsp),有时也称这种应用模式为Model 1,Model 1的主要缺点就是紧耦合,复用性差,维护成本高。

  由于Struts就是基于Model2实现的框架,所以它底层的机制也是MVC,我们通过图 2描述Struts的具体实现:


图 2 Struts MVC实现


  1.框架初始化

  Struts框架总控制器(ActionServlet)完成所有初始化工作。总控制器是一个Servlet,它通过web.xml配置成自动启动的Servlet,读取配置文件(struts-config.xml)的配置信息,为不同的Struts模块初始化相应的ModuleConfig对象。配置文件中的Action映射定义都保存在ActionConfig集合中,配置文件中其他配置信息分别保存在ControlConfig集合、FormBeanConfig集合、ForwardConfig集合和MessageResourcesConfig等集合中。

  要特别指出的是,初始化动作在Web容器启动时自动完成,初始化完成后,它将通过URL匹配映射截获所有以.do结尾的URL请求。

  2.客户端发送一个HTTP请求

  用户通过提交表单或调用URL向Web应用程序器提交一个请求,请求的数据用HTTP协议上传给Web服务器。

  3.总控制器接截获这个请求并实例化Form Bean

  控制器接收HTTP请求,并从ActionConfig中找出对应该请求的Action子类,如果没有对应的Action,控制器直接将请求转发给JSP或者静态页面。如果有对应的Action且这个Action有一个相应的Action Form,ActionForm被实例化并用HTTP请求的数据填充其属性,然后保存在Servlet Context中(request或session中),这样它们就可以被其它Action对象或者JSP调用。

  此外,还可以在ActionForm填充数据后还可以调用validate()进行数据有效性自检,并且可以返回一个包含所有错误信息的ActionErrors对象,如果ActionErrors不空,总控制器直接将请求返回到入口页面。

  4.控制器将请求转交给具体的Action处理

  控制器根据配置信息将请求切换到具体的Action,这个Form Bean也一并传给这个Action的execute()方法。

  5.Action完成具体的业务逻辑操作

  Action很简单,一般只包含一个execute方法,它负责执行相应的业务逻辑,如果需要,它也可能进行相应的数据检查。执行完成之后,返回一个ActionForward对象,控制器通过该ActionForward对象来进行转发工作。

  6.Action返回目标响应对象给总控制器

  Action根据业务处理的不同结果返回一个目标响应对象给总控制器,这个目标响应对象对应一个具体的JSP页面或另外一个Action。
 
  7.总控制器将HTTP请求转换到目标响应对象中。

  总控制器根据业务功能Action返回的目标响应对象,将HTTP请求转换到这个目标响应对象中,一般情况下,它是一个具体的JSP页面。

  8.目标响应对象将结果展现给用户
 
  目标响应对象(JSP)将结果页面展现给用户。

  客户端发送一个HTTP请求,通过Struts框架最后获得一个HTTP响应,这一过程非常重要,它是理解Struts框架的重点。图 2描述了Struts框架的结构,而图 3通过一个活动图更具体描述接受请求直至返回响应的整个过程:


图 3 Struts接受并返回响应的中间过程
  Struts1.1新增功能

  1、多模块的支持

  我们知道,在Struts 1.0中,只能在web.xml中为ActionServlet指定一个Struts配置文件(struts-config.xml),这对一个只需一两个人开发的小系统当然没有任何问题,但如果一个多人开发的大中型应用程序,问题就产生了。因为许多开发人员可能同时都需要修改Struts配置文件,这样肯定会造成一定程度的资源争夺,可能会出现彼此覆盖的情况,这样势必会影响开发效率并引起开发人员的抱怨。

  在Struts 1.1中,为了解决这个并行开发的问题,提出了两种解决方案:

  ·多个配置文件

  支持多个配置文件,是指你能够为ActionServlet同时指定多个xml配置文件,文件之间以逗号分隔,请看下面web.xml中关于多个struts配置文件的声明示例:

   代码清单 1 多个struts配置文件

1. <servlet>
2. <servlet-name>action</servlet-name>
3. <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
4. <init-param>
5. <param-name>config</param-name>
6. <param-value>
7. /WEB-INF/struts-config.xml, /WEB-INF/book-struts-config.xml
8. </param-value>
9. </init-param>
10. <load-on-startup>1</load-on-startup>
11. </servlet>


  通过这种方法,你可以为每一个模块定义一个配置文件,由于项目一般按模块划分工作,这样就大大地减小了冲突的概率。

  ·独立的模块

  但是,多个配置文件存在一个潜在的问题:不同的配置文件之间会产生冲突,因为在ActionServlet初始化的时候多个配置文件还是要合并到一起。比如,在struts-config.xml中配置了一个名为errorDbAccess的<exception>,而在book-struts-config.xml中也配置了一个同样的<exception>,这样就产生冲突了。

  为了彻底解决这种冲突,Struts 1.1中引进了模块(Module)的概念。一个模块就是一个独立的子系统,对应一个独立的配置文件,ActionServlet将不同模块的配置文件保存在各自独立的ModuleConfig对象中的。

  下面是两个独立模块的配置方式:

  代码清单 2 多模块配置方式

1. …
2. <init-param>
3. <param-name>config</param-name>

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:彻底搞定JSP的在线人数

下一篇:JBuilder2005 Struts深度体验之升级