Struts 与 MVC 模式

原创 2004年07月24日 11:09:00

Struts 框架:

Jakarta 的一个开放源代码项目,是基于 web 的 mvc 框架的实现,很适合开发大型 web 程序
Struts 自己实现了 Controller 的功能,只需要配置 xml 文件就可以控制页面间的流向
在 view 层提供了许多 tag 使我们能用简单的 tag 而减少网页里的代码量,甚至做到 jsp 网页里无代码
在 model 层,struts 提供了 Action ,来处理来自 jsp 的请求,和错误的处理
这样我们可以更多的把时间花在业务方面


Struts是使用 servlet 和 JavaServer Pages 技术的一种 Model-View-Controller 实现。Struts 可帮助您控制 Web 项目中的变化并提高专业化水平。尽管您可能永远不会用 Struts 实现一个系统,但您可以将其中的一些思想用于您以后的 servlet 和 JSP 网页的实现中。

模型-视图-控制器 (MVC)

JSP 标记只解决了部分问题。我们还得处理验证、流程控制和更新应用程序的状态等问题。这正是 MVC 发挥作用的地方。MVC 通过将问题分为三个类别来帮助解决单一模块方法所遇到的某些问题:

  • Model(模型)
    模型包含应用程序的核心功能。模型封装了应用程序的状态。有时它包含的唯一功能就是状态。它对视图或控制器一无所知。
  • View(视图)
    视图提供模型的表示。它是应用程序的外观。视图可以访问模型的读方法,但不能访问写方法。此外,它对控制器一无所知。当更改模型时,视图应得到通知。
  • Controller(控制器)
    控制器对用户的输入作出反应。它创建并设置模型。

“模型-视图-控制器”(MVC)

就是用来帮助您控制变化的一种设计模式。MVC 减弱了业务逻辑接口和数据接口之间的耦合。Struts 是一种 MVC 实现,它将 Servlet 2.2 和 JSP 1.1 标记(属于 J2EE 规范)用作实现的一部分。尽管您可能永远不会用 Struts 实现一个系统,但了解一下 Struts 或许使您能将其中的一些思想用于您以后的 Servlet 的 JSP 实现中。

Struts 概览

  • Client browser(客户浏览器)
    来自客户浏览器的每个 HTTP 请求创建一个事件。Web 容器将用一个 HTTP 响应作出响应。
  • Controller(控制器)
    控制器接收来自浏览器的请求,并决定将这个请求发往何处。就 Struts 而言,控制器是以 servlet 实现的一个命令设计模式。struts-config.xml 文件配置控制器。
  • 业务逻辑
    业务逻辑更新模型的状态,并帮助控制应用程序的流程。就 Struts 而言,这是通过作为实际业务逻辑“瘦”包装的 Action 类完成的。
  • Model(模型)的状态
    模型表示应用程序的状态。业务对象更新应用程序的状态。ActionForm bean 在会话级或请求级表示模型的状态,而不是在持久级。JSP 文件使用 JSP 标记读取来自 ActionForm bean 的信息。
  • View(视图)
    视图就是一个 JSP 文件。其中没有流程逻辑,没有业务逻辑,也没有模型信息 -- 只有标记。标记是使 Struts 有别于其他框架(如 Velocity)的因素之一。

Struts 的优点

  • JSP 标记机制的使用
    标记特性从 JSP 文件获得可重用代码和抽象 Java 代码。这个特性能很好地集成到基于 JSP 的开发工具中,这些工具允许用标记编写代码。
  • 标记库
    为什么要另发明一种轮子,或标记库呢?如果您在库中找不到您所要的标记,那就自己定义吧。此外,如果您正在学习 JSP 标记技术,则 Struts 为您提供了一个起点。
  • 开放源码
    您可以获得开放源码的全部优点,比如可以查看代码并让使用库的每个人检查代码。许多人都可以进行很好的代码检查。
  • MVC 实现样例
    如果您希望创建您自己的 MVC 实现,则 Struts 可增加您的见识。
  • 管理问题空间
    分治是解决问题并使问题可管理的极好方法。当然,这是一把双刃剑。问题越来越复杂,并且需要越来越多的管理。

Struts 的缺点

  • 仍处于发展初期
    Struts 开发仍处于初级阶段。他们正在向着发行版本 1.0 而努力,但与任何 1.0 版本一样,它不可能尽善尽美。
  • 仍在变化中
    这个框架仍在快速变化。Struts 1.0 与 Struts 0.5 相比变化极大。为了避免使用不赞成使用的方法,您可能隔一天就需要下载最新的 Struts。在过去的 6 个月中,我目睹 Struts 库从 90K 增大到 270K 以上。由于 Struts 中的变化,我不得不数次修改我的示例,但我不保证我的示例能与您下载的 Struts 协同工作。
  • 正确的抽象级别
    Struts 是否提供了正确的抽象级别?对于网页设计人员而言,什么是正确的抽象级别呢?这是一个用 $64K 的文字才能解释清楚的问题。在开发网页的过程中,我们是否应该让网页设计人员访问 Java 代码?某些框架(如 Velocity)说不应该,但它提供了另一种 Web 开发语言让我们学习。在 UI 开发中限制访问 Java 有一定的合理性。最重要的是,如果让网页设计人员使用一点 Java,他将使用大量的 Java。在 Microsoft ASP 的开发中,我总是看到这样的情况。在 ASP 开发中,您应该创建 COM 对象,然后编写少量的 ASP 脚本将这些 COM 对象联系起来。但是,ASP 开发人员会疯狂地使用 ASP 脚本。我会听到这样的话,“既然我可以用 VBScript 直接编写 COM 对象,为什么还要等 COM 开发人员来创建它呢?”通过使用标记库,Struts 有助于限制 JSP 文件中所需的 Java 代码的数量。Logic Tag 就是这样的一种库,它对有条件地生成输出进行管理,但这并不能阻止 UI 开发人员对 Java 代码的狂热。无论您决定使用哪种类型的框架,您都应该了解您要在其中部署和维护该框架的环境。当然,这项任务真是说起来容易做起来难。
  • 有限的适用范围
    Struts 是一种基于 Web 的 MVC 解决方案,所以必须用 HTML、JSP 文件和 servlet 来实现它。
  • J2EE 应用程序支持
    Struts 需要支持 JSP 1.1 和 Servlet 2.2 规范的 servlet 容器。仅凭这一点远不能解决您的全部安装问题,除非使用 Tomcat 3.2。我用 Netscape iPlanet 6.0 安装这个库时遇到一大堆问题,按理说它是第一种符合 J2EE 的应用程序服务器。我建议您在遇到问题时访问 Struts 用户邮件列表的归档资料(请参阅网上资源
    )。
  • 复杂性
    在将问题分为几个部分的同时也引入了复杂性。毫无疑问,要理解 Struts 必须接受一定的培训。随着变化的不断加入,这有时会令人很沮丧。欢迎访问本网站。
  • 在何处...
    我还能指出其他问题,例如,控制器的客户端验证、可适用工作流程和动态策略模式在什么地方?但是,目前这太容易成为吹毛求疵的问题,有些问题是无关紧要的,或者说应该对 1.0 发行版提这些问题。随着 Struts 小组的不断努力,到您阅读本文时 Struts 说不定已经有了这些功能,或者它很快就会具有这些功能。

Struts 的前景
在这个软件开发的新时代,一切都变得很快。在不到 5 年的时间内,我已经目睹了从 cgi/perl 到 ISAPI/NSAPI、再到使用 VB 的 ASP、一直到现在的 Java 和 J2EE 的变迁。Sun 正在尽力将新的变化反映到 JSP/servlet 体系结构中,正如他们对 Java 语言和 API 所作的更改一样。您可以从 Sun 的网站获得新的 JSP 1.2 和 Servlet 2.3 规范的草案。此外,一个标准 JSP 标记库即将出现;有关这些规范和标记库的链接,请参阅网上资源

最后的注释
Struts 使用标记和 MVC 解决了某些重大问题。这个方法有助于提高代码的可重用性和灵活性。通过将问题划分为更小的组件,当技术空间或问题空间中出现变化时,您就有更多的机会重用代码。此外,Struts 使网页设计人员和 Java 开发人员能将精力集中于自己最擅长的方面。但是,在强健性增强的同时,也意味着复杂性的增加。Struts 比简单的单个 JSP 网页要复杂得多,但对于更大的系统而言,Struts 实际上有助于管理复杂性。另外,我并不想编写自己的 MVC 实现,而只想了解一个这样的实现。不管您是否会使用 Struts,回顾这个 Struts 框架(对不起,应该是库)都会使您对 JSP 文件和 servlet 的特性、以及如何将它们组合起来用于您的下一个 Web 项目有更好的了解。正像翼间支柱是机翼结构中不可缺少的一部分一样,Strut 也可能成为您下一个 Web 项目的不可缺少的一部分。

基于MVC模式的Struts框架概述

作者:yarshray 关键字: Java  J2EE  MVC  JSP  Servlet  MVC  Struts 内容简介:       MVC设计模式成为了目前十分流行的一种设计方法.它是一种...
  • yarshray
  • yarshray
  • 2005-04-20 23:10:00
  • 6210

Struts2概述与MVC模式

truts分为两个主要版本,struts1和struts2,struts2是由webwork2发展而来的 1、Framework概念:将相同类型问题的解决途径进行抽象,抽取成为一个应用框架。这就是F...
  • IT_LOSER
  • IT_LOSER
  • 2016-10-13 14:13:33
  • 1558

Struts对MVC的实现流程

文章的主题是Struts对MVC的实现流程,那么,首先要解决的问题是:什么是MVC?     MVC是Model—View—Controler的简称。即模型—视图—控制器。MVC是一种设计模式,它...
  • sunqing0316
  • sunqing0316
  • 2015-09-28 15:51:30
  • 2071

Struct入门(一)——Struts2-MVC模式入门

1.MVC模式   MVC模式一种架构的体现,不引入新的功能,只是令应用的模型和视图分离,从而达到更好的开发和维护效率。在MVC模式中,应用程序被划分为了Model,View,Controller三个...
  • changyinling520
  • changyinling520
  • 2017-02-12 22:38:24
  • 879

Servlet 和 Struts中的Action属于MVC中的C(Controler)

众所周知,Servlet 和 Struts中的Action是属于MVC中的C(Controler),只是一个控制器, 按说在两者之中是不应该出现业务代码的,它们只是一个控制器,只负责将视图(JSP页面...
  • zhlu2009
  • zhlu2009
  • 2009-05-30 14:06:00
  • 534

Struts是如何实现MVC的

上篇文章说到用servlet实现的一些弊端,下面,我们就解决一下这个问题,我们用struts来实现一个登陆的实例。 首先,了解一下struts与MVC的一一对应关系: Model:The Mode...
  • laner0515
  • laner0515
  • 2013-09-06 21:52:10
  • 9911

Struts2实现MVC(概念解析)

框架简述 什么是框架:框架就是能完成一定基础功能的半成品软件。在没有框架时,所有的工作都要从最底层做起;但是有了框架后,它可以为我们提供一定的基础功能,我们就可以在框架的基础上进行开发,而无需自己去实...
  • a_good_programer
  • a_good_programer
  • 2016-09-07 20:45:19
  • 1100

MVC模式和Struts框架.rar

  • 2008年11月07日 09:06
  • 697KB
  • 下载

Struts MVC 框架 (让你一步步成为高手)

web应用的分层 交互层,表现数据,收集数据,也就是视图层,接受请求,通过处理层完成相应的响应。(V,C) 处理层,完成数据的处理,也就是业务层(M)。 MVC设计模式(应用观察者...
  • lidongya1181
  • lidongya1181
  • 2016-07-01 08:42:55
  • 5535

Struts之mvc设计模式

MVC(Model-View-Controller)MVC是一种架构型模式。是用来指导我们改善应用程序的架构,使得应用的模型和视图相分离,从而得到更好的开发和维护效率。 MVC结构提供了一种...
  • chajinglong
  • chajinglong
  • 2015-08-14 23:03:32
  • 607
收藏助手
不良信息举报
您举报文章:Struts 与 MVC 模式
举报原因:
原因补充:

(最多只允许输入30个字)