当前流行的 J2EE WEB 应用架构分析责任编辑: 覃里作者: IBM developerworks 网站 2009-11-19 来源: IT168 网站文本 Tag :Struts Java JSF 【 IT168 技术文章】J2EE 体系包括 java server pages(JSP) ,java SERVLET, enterprise bean ,WEB service 等技术。这些技术的出现给电子商务时代的 WEB 应用程序的开发提供了一个非常有竞争力的选择。怎样把这些技术组合起来形成一个适应项目需要的稳定架构是项目开发过程中一个非常重要的步骤。完成这个步骤可以形成一个主要里程碑基线。 1. 架构概述 J2EE 体系包括 java server pages(JSP) ,java SERVLET, enterprise bean , WEB service 等技术。这些技术的出现给电子商务时代的 WEB 应用程序的开发提供了一个非常有竞争力的选择。怎样把这些技术组合起来形成一个适应项目需要的稳定架构是项目开发过程中一个非常重要的步骤。完成这个步骤可以形成一个主要里程碑基线。形成这个基线有很多好处: 各种因数初步确定为了形成架构基线,架构设计师要对平台(体系)中的技术进行筛选,各种利弊的权衡。往往架构设计师在这个过程中要阅读大量的技术资料,听取项目组成员的建议,考虑领域专家的需求,考虑赞助商成本(包括开发成本和运行维护成本)限额。一旦架构设计经过评审,这些因数初步地就有了在整个项目过程中的对项目起多大作用的定位。定向技术培训一旦架构师设计的架构得到了批准形成了基线,项目开发和运行所采用的技术基本确定下来了。众多的项目经理都会对预备项目组成员的技术功底感到担心; 他们需要培训部门提供培训,但就架构师面对的技术海洋,项目经理根本就提不出明确的技术培训需求。怎不能够对体系中所有技术都进行培训吧!有了架构里程碑基线,项目经理能确定这个项目开发会采用什么技术,这是提出培训需求应该是最精确的。不过在实际项目开发中,技术培训可以在基线确定之前与架构设计并发进行。角色分工有了一个好的架构蓝图,我们就能准确划分工作。如网页设计,JSP 标签处理类设计, SERVLET 设计, session bean 设计,还有各种实现。这些任务在架构蓝图上都可以清晰地标出位置,使得项目组成员能很好地定位自己的任务。一个好的架构蓝图同时也能规范化任务,能很好地把任务划分为几类,在同一类中的任务的工作量和性质相同或相似。这样工作量估计起来有一个非常好的基础。运行维护前面说过各个任务在架构图上都有比较好的定位。任何人能借助它很快地熟悉整个项目的运行情况,错误出现时能比较快速地定位错误点。另外,有了清晰的架构图,项目版本管理也有很好的版本树躯干。扩展性架构犹如一颗参天大树的躯干,只要躯干根系牢,树干粗,长一些旁支,加一些树叶轻而易举无疑。同样,有一个稳定的经得起考验的架构,增加一两个业务组件是非常快速和容易的。大家都知道这些好处,一心想形成一个这样的 J2EE 应用程序架构(就像在 windows 平台中的 MFC) 。在这个路程中经历了两个大的阶段: . 模型 1模型 1其实不是一个什么稳定架构,甚至谈不上形成了架构。模型 1的基础是JSP 文件。它从 HTTP 的请求中提取参数,调用相应的业务逻辑,处理 HTT P 会话,最后生成 HTTP 文档。一系列这样的 JSP 文件形成一个完整的模型 1应用, 当然可能会有其他辅助类或文件。早期的 ASP 和PHP 技术就属于这个情况。总的看来,这个模型的好处是简单,但是它把业务逻辑和表现混在一块,对大应用来说,这个缺点是令人容忍不了的。 . 模型 2在经过一番实践,并广泛借鉴和总结经验教训之后, J2EE 应用程序终于迎来了 MVC( 模型-视图-控制)模式。 MVC 模式并不是 J2EE 行业人士标新立异的,所以前面我谈到广发借鉴。MVC 的核心就是做到三层甚至多层的松散耦合。这对基于组件的,所覆盖的技术不断膨胀的 J2EE 体系来说真是福音和救星。它在浏览器(本文对客户代理都称浏览器)和JSP或SERVLE T之间插入一个控制组件。这个控制组件集中了处理浏览器发过来的 HTTP 请求的分发逻辑,也就是说,它会根据 HTTP 请求的 URL, 输入参数,和目前应用的内部状态,把请求分发给相应的 WEB 层的 JSP 或SERVLET 。另外它也负责选择下一个视图(在J2E E 中,JSP,SERVLET 会生成回给浏览器的 html 从而形成视图)。集中的控制组件也有利于安全验证,日志纪录,有时也封装请求数据给下面的 WEB tier 层。这一套逻辑的实现形成了一个像 MFC 的应用框架,位置如图
J2EEWEB的应用架构分析 来自淘豆网m.daumloan.com转载请标明出处.