通过Struts应用MVC设计模型

设计

  模型--视图--控制器(Model-View-Controller,MVC)体系突出了Servlets和JSP的优点,同时也令它们的缺点最小化。在实现中,用户请求被发送到一个控制器servlet,该servlet决定请求的性质,并且根据请求的类型传送给适合的处理器。每个处理器都和一个特别的模型相关,里面封装有商业逻辑来执行一些特别的函数集合。处理完毕后,结果会发送回处理器,处理器选择适合的视图显示它。

  Struts最早于2002年5月作为Jakarta项目的组成部分问世,Jakata项目由Apache Foundation.运做。项目的创立者希望该项目的研究改进和提高Java Server Pages (JSPs)、servlet、标签库以及面向对象的技术水准。Struts为使用MVC体系来编写应用提供了一个架构。Struts使用“ActionMapping”,它允许servlet将用户的请求转变为应用行为。ActionMapping通常指定一个请求的路径、在请求上进行动作的对象类型,以及指定其它需要的属性。

  Action对象作为ActionMapping的一个部分使用,负责处理请求,并且发送响应回适合的视图(通常是一个Web浏览器),或者传送请求至适合的模型。

  在模型和视图间的桥是一个form bean,它可以通过继承org.apache.struts.action.ActionForm得到。form bean用来保存处理前的用户数据,或者显示返回给用户的模型数据。Struts包含有自定义的标签,它可以由创建的form bean中自动组合字段。

  在实践中用户请求JSP页面,控制器servlet接收请求并决定由哪个应用处理它。Action对象传送该请求到包含有接收商业逻辑的JavaBean中。商业逻辑bean将连接数据库并进行查询,接收结果,然后返回结果给Action对象。Action对象将结果作为请求的一部分存放到一个form bean中。一旦收集完请求的全部数据,就可以格式化结果并且显示。最后是JavaServer Page以HTML表格的形式将结果显示出来。

  模型,控制器和视图

  Struts中的控制器的基本组件是ActionServlet类中定义的servlet,它是由ActionMappings定义的。ActionMapping类表示的是Action对象的名字和位置。当一个请求进入控制器时,它将请求的路径映射到Action的位置,并且将请求传送给Action。Struts的ActionMapping类还可能包含有其它的信息,这些信息可能只是与你的应用相关,例如本地变量,环境变量或者其它URIs。

  Struts的关键是控制器周围的活动。Struts控制器servlet映射事件到类(一个事件通常是一个HTTP POST, GET,或者类似的请求)。ActionServlet是MVC设计模型的司令部,也是Structs架构的核心。ActionServlet创建和使用Action,一个ActionForm和ActionForward。struts-config.xml是用来设置Action的。在创建Web应用期间,采用扩展Action和ActionForm来解决如何响应用户请求的问题。struts-config.xml则是告诉ActionServlet如何使用扩展类。也可扩展ActionServlet以令Structs应用带有一些自定义的特性。

  这个方法有几个优点。首先,应用的整个逻辑流都是在一个分等级的文本文件中。这样就可以比较容易地查看、理解应用,特别是大的应用。第二,编写网页的人在修改网页时就无需遍历Java代码来理解应用的流程,而Java开发者在改变流程的时候也无需重新编译代码。

  ActionForm为Web应用维护session状态。ActionForm是一个抽象类,它可以被每个输入表格模型扩展。它代表数据的一般概念,可以被HTML表格设置或者更新。例如,你的应用也许拥有一个被HTML表格设置的UserActionForm。Struts的架构将检查UserActionForm是否存在,如果不存在,就会创建一个该类的实例。Structs将会使用HttpServletRequest的相应字段来设置UserActionForm的状态。在传送UserActionForm给商业封装层的UserAction前,Struct架构先更新UserActionForm的状态。

  Structs模型包含有系统的状态和它可以接受的操作。可以使用各种各样的结构来表示模型(例如其它servlets或者JSP),不过在大多数的时候你都会使用JavaBeans。JavaBean的属性,或者在Enterprise JavaBeans (EJBs)中由外部数据源得到的数据--表示的是状态,而方法则是表示可以在上面进行的操作。操作并不需要被JavaBean方法定义;在简单的情况下,操作可以放置到Action对象中,虽然这样会令处理和分级之间的区别变得模糊。

  Struts MVC应用的视图通常由JSP构造,它可以使用HTML或者XML静态格式化页面,还提供了一个方法可动态插入自定义的内容来响应用户的请求。Structs的一个关键是它的自定义标签库,它提供了一个方法,可以很容易地使用JSP来创建用户界面。

  Structs架构包含有自定义的标签库,可以通过各种不同的方式使用。虽然就使用该架构来说,这些库并不是必须的,不过它们包含的标签在你的应用的许多地方都很有用。Structs的一些标签库包括有:

  . structs-html标签库。该库可以用作创建动态HTML用户界面或者表格。

  . structs-bean标签库。对于将JavaBean代码放到JSP页面,该库提供了一个加强方式,通过 标签实现。

  . struts-logic标签库。该库可以管理有条件地产生输出文本,遍历对象collections以重复地产生输出文本,还有应用流控制。

  . struts-template标签库。该库包含的标签可用作为页面创建动态的JSP模板,这些页面都拥有一个公共的外观或者公同的格式。

  使用这些标签库和其它的任何库都是一样的。因为库已经写好了,你所要做的就是告诉servlet引擎要使用它。在Tomcat中,你可以通过web.xml文件中的<taglib>标签来指定标签库的URI,以及Web服务器系统上标签库描述文件的位置。

  The Small Print

  Jakarta工程可让你下载Structs的二进制版本,或者直接由源代码中编译它。二进制版工作得很好,不过如果你拥有一个不常见的软件平台,或者想学习一下如何编译它,也不是很困难。无论你的选择如何,Structs都需要以下几个软件:

  . Java Development Kit (JDK). 你需要为你的操作系统下载和安装一个Java 2 JDK实现。

  .Servlet容器。你还需要下载和安装一个兼容Servlet API规范(2.2版以上)、JSP规范(1.1版以上)的servlet容器。一个好的选择是下载Apache的Tomcat,它可以支持网页服务,并且可以运行servlet和JSP。

  .XML解析器。Struts需要一个兼容Java API for XML Parsing (JAXP)规范(1.1版或以上)的XML解析器。

  .Servlet API类。为了编译Structs或者使用Structs的应用,你将需要一个包含有servlet和JSP API类的servlet.jar文件。大部分的servlet容器都包含有这个JAR文件。

  .JDBC 2.0 optional package类。Structs支持javax.sql.DataSource的一个可选实现,因此它需要这些API类来编译。你可以在这个网址下载这些包类:http://java.sun.com/products/jdbc/download.html

  要使用Structs来建立一个应用,需要遵从以下步骤。首先,将Structs中的lib/commons-*.jar和 lib/struts.jar文件拷贝到应用中的WEB-INF/lib目录。然后将Structs中的全部标签库描述文件(lib/struts-*.tld)拷贝到你的Web应用中的WEB-INF目录。

  拷贝完这些文件后,你就可以修改Web应用中的web.xml文件,令它包含有一个<servlet>元素来定义控制器servlet,还有一个<servlet-mapping>元素以指明哪个请求的URI被映射到这个servlet。如果你使用默认的目录来进行一个标准的安装,你可以使用Struts例子应用中的web.xml文件来作为一个参考,看它是如何设置的,然后你就可以修改Web应用中的web.xml文件来指定适当的标签库声明。再次申明,你可以由Structs的例子应用中学习如何设置。

  修改完web.xml文件后,在WEB-INF目录创建一个称为struts-config.xml的文件,在其中定义操作映射和其它与你的应用相关的特性。最后,在每个将使用Struts自定义标签的JSP页面的顶部,加入Struts自定义标签的声明。

  Struts这个名字来源于在建筑和旧式飞机中使用的支持金属架。它的目的是为了帮助你减少在运用MVC设计模型来开发Web应用的时间。你仍然需要学习和应用该架构,不过它将可以完成其中一些繁重的工作。如果想混合使用servlets和JSP的优点来建立可扩展的应用,Struct可以帮助你完成其中的一些工作。

时间: 2024-09-20 18:36:29

通过Struts应用MVC设计模型的相关文章

用Struts建立MVC应用

本文讲述了如何用Struts建立MVC应用. Model 1 和Model 2简介 我们在开发Web应用时经常提到的一个概念是Model 1/Model 2,那么到底它是什么意思呢?其实它是对采用JSP技术构成Web应用的不同模型的描述.下面对这个概念做一个简单的介绍. Model 1 在使用JAVA技术建立Web应用的实例中,由于JSP技术的发展,很快这种便于掌握和可实现快速开发的技术就成了创建Web应用的主要技术.JSP页面中可以非常容易地结合业务逻辑(jsp:useBean).服务端处理过

ASP.NET MVC数组模型绑定详解_实用技巧

在ASP.NET MVC中使用Razor语法可以在视图中方便地展示数组,如果要进行数组模型绑定,会遇到索引断裂问题,如下示例: <input type="text" name="[0].Name" /> <input type="text" name="[1].Name" /> <input type="text" name="[2].Name" />

HMVC 框架设计模型

HMVC 框架设计模型,HMVC 框架设计模型,HMVC 框架设计模型,HMVC 框架设计模型 

计费方案-java 理赔费用设计模型

问题描述 java 理赔费用设计模型 现在正在设计某保险公司的理赔赔付模型,赔付是按照险种进行计算的,例如医疗门诊险的赔付是 按照 (账单有效金额-免陪额)*赔付比例来计算的,不同的险种有不同的计算因子和不同的计算公式,请问,这类设计可以用哪块引擎解决呢: 我现在想到的是规则引擎,和动态sql.业界还有哪些通用的解决方案呢? 解决方案 我们都是用规则引擎来实现理赔,理算模型,做了好几年了,效果非常不错,无论是保单的处理效率还是赔付结果的正确性都提高了好多倍,以下是我们用规则引擎实现的理赔模型截图

asp.net mvc 修改模型实体类的代码问题

问题描述 asp.net mvc 修改模型实体类的代码问题 修改类的字段的属性等后就会出错,DBContext更改,我网上搜索了Code First的方法,但是我是多个类都修改了,每个类都对应一个Context,请问应该要怎么改? 解决方案 干嘛每个实体类对应一个context,这不是自找麻烦么?如果非要这样,当然要分别修改了.

让技术人员看得懂的流程(4)——设计模型

                       让技术人员看得懂的流程(4)                                     --设计模型 完成了"领域模型"阶段后,面向对象已经初具雏形,我们已经看到了那熟悉的"对象"了,例如"商品"."交易"."商品清单"等,看起来已经进入了面向对象的世界了,你是否已经摩拳擦掌,跃跃欲试,准备开始编码了呢? 且慢,"领域模型"只是

Java 高并发七:并发设计模型详解_java

1. 什么是设计模式 在软件工程中,设计模式(design pattern)是对软件设计中普遍存在(反复出现)的各种问题 ,所提出的解决方案.这个术语是由埃里希·伽玛(Erich Gamma)等人在1990年代从建筑设计领 域引入到计算机科学的. 著名的4人帮: Erich Gamma,Richard Helm, Ralph Johnson ,John Vlissides (Gof) <设计模式:可复用面向对象软件的基础>收录23种模式 2. 单例模式 单例对象的类必须保证只有一个实例存在.许

java 设计模型之单例模式详解_java

Singleton 模式的宗旨在于确保某个类只有一个实例,别且为之提供一个全局访问点.为了防止其他工作人员实例化我们的类, 可以为该类创建唯一一个构造器,并将构造器的可见设置为私有.值得注意的是,如果我们创建了其他的非私有的构造器,或者根本没有为该类提 供构造器,那么其他人员还是能实例化我们的类. 如果不希望提前创建单例对象,我们可以等到第一次使用该单例对象的时候在创建它,即 滞后初始化.滞后初始化单例对象有两个理由: 1.也许在静态初始化时间,你没有关于如何初始化单例对象的足够信息. 2.选择

python代码简单模拟Java中的MVC设计

python代码简单模拟Java中的MVC设计 包括两个文件: 一. mymvc.py import tornado.ioloop import tornado.web #访问地址 http://127.0.0.1:9870/main?ywdm=06&num1=10&num2=200 class TestClassA: def sub(self,a,b): return a-b def add(self,a,b): return a+b def chen(self,a,b): return