`
yingfang05
  • 浏览: 121567 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

无框架架构模型探讨:简化的Java EE开发之一

阅读更多
Java EE是个相当复杂的东西,被很多开发者们视为庞然大物。在下面的文章中,javaonejcy探讨了如何简化Java EE开发中不必要的复杂,并给出一个不使用任何框架的架构模型。

你可以说可爱的php ,可爱的ror ,可爱的python ,甚至可爱的.net ,但是Java EE ?他太复杂了。相比其他两种技术,Java EE 的技术体系更全面、更规整也更复杂,他的复杂性也让很多厂商望而止步,宁可选择简单甚至简陋的php ,这充分说明快速开发是这个时代最迫切的需求。

Java EE 的servlet 、javabean 、jdbc 规范给了我们组件和容器的唯一标准,而更高级的支持,jsf 、jdo 规范却没能给予我们唯一的框架级标准,他们被认可的程度远低于相同领域的开源框架。尽管开源社区给了我们最丰富的选择,但是相比.net 、php 、ror 的全栈式服务,Java EE 开发者必须DIY 。DIY 不但需要时间而且需要冒险,这种发烧友做的事情是企业所不愿意做的。一段时间以来,公司Java EE 方向的招聘几乎清一色的要求struts 、spring 、hibernate 这几种主流框架的能力就是一种证明。

Java EE 的开发往往避免不了配置之旅,尽管很多框架都有自动生成工具,但是,面对一个中型项目,仍然容易造成混乱。配置使你无论在开发、测试、集成还是维护的时都要配置代码两头看。配置给了框架一个注入服务的切入点,但是对人并无优雅可言。ror 给了我们启发,尽管企业开发是复杂的,但是大多数的需求都是通用的,事实证明,ror 把这部分通用性用约定的方式抽象得很好。其实Java EE 并不缺乏约定,因为他本身就是建立于一系列规范的基础之上,而规范就是约定。所以,Java EE 实际上有机会成为相对简洁的开发技术,只不过由于种种原因,这种规范并未出现。

在众多的Java EE 开发框架中,struts+spring+hibernate 有着黄金组合的美誉,用的人多,会的人多,就算是没出校门的学生,也知道学会ssh 的重要性。但是学会和学懂是两码事,对于一个中型项目,ssh 就成了一柄双刃剑,需要由高水平的设计师引路,才能披荆斩棘。spring+hibernate 给了设计者广阔的空间,而设计需要因项目的前进而演进,如果你的项目进度紧张,人手不足,设计质量就难以保障,给系统带来隐患。

“任何优秀的语言,都可以帮助开发者写出优秀的代码,但不能阻止开发者写出糟糕的代码”。在这一点上,无论是Java EE ,.net ,ror ,php 都不会例外。而开发框架就像是“一间有很多屋梁的房子”,“框架的强大之处不是他能让你做什么,而是他不能让你做什么”,其实如同语言一样,框架虽然可以给予开发一定程度的规范指导,但是这种指导仍然是有限的,这真应了那句老话:事在人为。

本文试图探讨如何简化Java EE 开发中不必要的复杂,并给出的是一个不使用任何框架的架构模型,让我们看看仅仅通过用编码约定,结构设计和使用方式的组合能不能满足项目开发的主要需求— 短期培训,降低隐患和快速开发。

问题的源头

应用软件开发是复杂的,但其基本模型至为简单,请求-处理-响应。对应于软件的层次结构就是:请求-Cortrol (C );处理-Model (M );响应-View (V )。在早期的Java EE 应用中,servlet 负责C ,javabean 和jdbc 在M ,jsp 是V 。这些就是Java EE 的基础设施,他们职责划分的方式被称为JSP Model2 ,已经可以满足web 开发的基本需要,Java EE 的开发始终都围绕着这几项主要技术,框架也不例外。以下的内容,将从这些技术的应用与不足说起,然后介绍主流框架的解决方案,之后再介绍我们不用框架的处理方式。

(C) 选择控制器

基础规范的不足

任何web 应用,处理请求之后返回响应是必须的环节,如果编码规范,传统的响应就是转向到某个页面,servlet 处理转向有两种方式,其中request 转向隐藏着重复提交的问题,response 重定向带来参数传递的编码解码的问题,同时众多的转向地址直接写在servlet 中也十分不雅,另外,jsp 和javabean 有一种出色的关联技术,就是在jsp 里可以把来自请求表单的数据自动拼装到javabean 中。糟糕的是,这么有用的技术却无法在servlet 中使用,所以Model2 缺乏对表单数据的自动转换处理。servlet 有这些不足很好理解,因为servlet 毕竟是较早出现的技术,他的职责只是将(http )请求转化为面向对象的视图和输出响应而已,由于他是低阶组件,所以部分功能的缺失是正常的。不过这就让servlet 成为了Model2 最薄弱的一环。

开发框架的解决方案

由于以上需求是共性的,所以编写一个通用框架就成为了很多人努力的事情,struts 很快推出并且很快流行。我们先来看一看struts 的特性:

前端控制器: struts 使用一个servlet 作为前端控制器,所有请求先经过这里,再分派给配置指定的action (这里是指行为,而不是具体的Action ),意图是以一个中间层将视图层和控制层解耦,这种思路带来了三种可能的好处:1 视图和控制分离,所以可以选择不同的视图技术,比如视图模板既可以用jsp ,也可以用Volecity 、FreeMarker ;2 可以对所有请求预处理,和后处理(webwork );3 可以将响应的转向地址管理起来。前端控制器也存在一种直接的不足:配置繁琐。

ActionForm : struts 主要是一个控制层框架,所以他并不意图深入到模型层,ActionForm 是一种无奈的选择,尽管提供了表单数据到javabean 的转换,但是遗憾的是这个javabean 并不能直接使用,还要手工的转换为模型javabean ,使得ActionForm 的位置有些尴尬。

国际化支持、标签库和全局异常: 国际化和标签库都是struts 的亮点,不过全局异常作用有限。

我们的选择

Java EE 的控制器必然是一个servlet ,我们也不能例外,因为我们必须要运行在servlet 容器之中。不过,我们选择的是servlet 的演进版本-jsp 。别误会,我们并不是要退回到JSP Model1 。一个典型的示例是,如果我有一个员工信息录入的功能点,那么为了实现这个功能,我可以建立下面两个文件:

worker_input.jsp

worker_inputOper.jsp

worker_input.jsp 里不写控制代码,worker_inuptOper.jsp 里也不写视图代码,这种用法实际是JSP Model1 和JSP Model2 的综合体。这样做最大的好处就是,免去配置的烦恼,但是等等.. 前端控制器呢?我们的中间层呢?

考虑一下,你有一个企业信息的表单,表单中有一个企业名称域,对这个域的要求是不能在已有企业中重名,域旁边有一个按钮,业务员可以通过点击这个按钮获得录入企业名称是否重复的提示。如果是传统方式,点击按钮将导致一个页面提交,如果用struts ,将要配置这个action 处理之后转向的URL 地址,这就是传统web 应用的响应方式- 基于URL 地址的页面导航。

web2.0 来了,ajax 来了,异步请求的出现彻底颠覆了传统的web 交互模型。对于ajax 应用而言,服务器端返回响应只需要out.print ,请求从哪来,回哪去,转向(如果需要)和更新视图的任务都交给了客户端脚本,也就是说,基于异步交互模式的web 应用,根本就没有需要配置的result URL 路径。这样,页面导航的问题就自动解决了。而对于预处理,我们可以用filter 替代。所以,我们完全可以和前端控制器说:再见。

由于客户端技术的趋势,在webappdemo 中我们将全面使用ajax 。也许你会说,如果客户端浏览器禁用脚本呢?这个担心在如今已经没有必要,你可以访问开心或者当当,看看禁用脚本他们能不能工作。时代在进步,富客户RIA 是必然的选择。

使用jsp 作为控制器,还使我们得到了另一个关键的特性,那就是从form 表单数据到javabean 的自动创建和输入,使javabean 本身既是模型也是DTO ,再也不必象ActionForm 那样还要手工转换。这里还有一个隐含的好处,就是强制统一了表单域名和模型属性名,不然,有可能出现这样的情况:表单域:child_center ;模型属性:branch 。以下是worker_inputOper.jsp 的写法:

Jsp代码

< jsp:useBean id="worker" class="webappdemo.worker.entity.Worker" scope="page"/>     < jsp:setProperty name="worker" property="*"/>          < %               response.setContentType("text/x-json;charset=UTF-8");          response.setHeader("Cache-Control", "no-cache");               String method = request.getParameter("method");              if("save".equals(method)){              EntityService es = new EntityService();              Message m = es.add(worker);              out.print(new JSONObject().put(m.isSucceed()?"succeed":"error", m.getMessage()));             return;          }          %>  

可以看出,只需将实体类名引入标签,我们就可以获得自动可以看出,只需将实体类名引入标签,我们就可以获得自动拼装的Worker 对象。对于复杂对象或复合对象,由于request 里同样有我们需要的所有请求参数,所以你可以在自动创建的javabean 基础上修改部分属性,以符合业务需要。

代码还展示了基于“method ”的用法,这只是一个字符串,用来告诉oper jsp 要用哪个方法来处理请求,这类似于ror 控制器内部定义的方法以及struts 的DispatchAction 但比他更灵活,变通的解决了jsp 的请求不能直接面向方法的不足。

在调用服务处理请求之后,worker_inputOper.jsp 将处理结果out.print 回客户端,这句代码的意思是新建一个JSON 对象,将处理结果添加进去,然后输出这个对象,方便客户端js 脚本解析。JSON 对象可以增加多个处理结果,只要他们的key 不同就可以。在实际应用中,往往返回处理消息,或者html 视图的字符串。最后别忘了return; 否则程序仍然会向下进行。

如果你的项目需要国际化,我们可以使用fmt 标签,而对于反馈消息的国际化,我们也许就需要建立一个全局MessageSource 对象了,这个问题在webappdemo 中没有涉及,因为笔者认为这不是普遍需求。

对于异常处理,其实jsp 已经提供了简单的机制,我们可以在web.xml 中配置:

Xml代码 

< error-page>  
    < error-code>404< /error-code>  
    < location>/404.jsp< /location>  
< /error-page>  
< error-page>  
    < error-code>500< /error-code>  
    < location>/500.jsp< /location>  
< /error-page>
这种简单的处理其实正是我们需要的全部,因为笔者认为,web 应用的系统错误和java 的异常没有区别,即检测错误和运行时错误。在web2.0 时代,所有的错误都应该被捕获,并且把内容经处理后在用户输入位置反馈给用户,而不应该重新定向。运行时错误属于系统bug ,是需要修复的代码级错误,这种错误是真正的“意外”,所以我们用定制的错误页面反馈给用户就可以了。

综上所述,我们用ajax+jsp+ 控制jsp 的方式代替了servlet 或者action ,摆脱了前端控制器,用模型javabean 代替了过程javabean ActionForm ,这些使用方式使我们不需要配置即可以开发应用程序,除了ajax 是相对新概念外不需要额外学习框架技术也是他的优点。
分享到:
评论

相关推荐

    Beginning Java EE 7.pdf

    - **JavaServer Faces (JSF)**:一种用于构建用户界面的框架。 #### 三、各章节详细知识点解析 ##### 第1章:Java EE 7 概览 - **内容概要**:介绍了 Java EE 7 的新特性和改进之处,以及这些特性如何帮助开发者...

    Spring 3.x 权威指南:实施Java EE 6 的利器

    总的来说,《Spring 3.x 权威指南:实施Java EE 6 的利器》是一本全面覆盖Spring框架与Java EE 6集成的教程,对于希望提升Spring技能和深入理解企业级开发的程序员来说,是不可多得的参考书籍。通过阅读和实践,读者...

    Java EE 框架整合开发⼊⻔到实战——Spring+Spring MVC+MyBatis(微课版)课后习题答案.pdf

    这份文档名为《Java EE 框架整合开发入门到实战——Spring+Spring MVC+MyBatis(微课版)课后习题答案.pdf》,它显然是关于Java EE中流行的三个框架整合使用的教程。这三个框架分别是Spring、Spring MVC和MyBatis,...

    Cairngorm+java EE 例子源码

    Java EE(Enterprise Edition)则是一个全面的后端企业级开发平台,包含了各种服务和组件,如Servlet、JSP、EJB等,用于构建分布式、多层的企业系统。 在这个"Cairngorm+Java EE"的例子中,我们可以探讨以下几个...

    java ee 6 with glassfish 3

    Java EE 6简化了企业级开发,引入了模块化的架构,包括Web Profile和Full Profile。Web Profile为轻量级应用提供必要的服务,如Servlet、JSP和JSF,而Full Profile包含所有API,适合大型企业应用。关键更新包括:...

    java web 2.0架构开发与项目实战 源代码01

    在本资源中,"java web 2.0架构开发与项目实战 源代码01",我们聚焦于Java Web应用程序的开发,特别是在Web 2.0时代的技术和实践。Web 2.0是一个概念,它强调互联网作为交互式平台,用户参与度更高,社交网络和富...

    Real World Java EE Patterns Rethinking Best Practices

    《Real World Java EE Patterns: Rethinking Best Practices》是一本深入探讨Java EE开发模式及其最佳实践的书籍。作者Adam Bien通过丰富的实战经验,对传统的Java EE设计模式进行了重新审视,并提出了许多新的见解...

    轻量级Java_EE企业应用实战_Struts_2+Spring_3+Hibernate整合开发_第3版

    《轻量级Java_EE企业应用实战_Struts_2+Spring_3+Hibernate整合开发_第3版》这本书深入探讨了在Java EE环境下如何利用轻量级框架Struts 2、Spring 3和Hibernate进行高效的企业级应用开发。这三者结合在一起,形成了...

    一种Java EE多层架构下的大学物理实验系统.pdf

    在探讨一种Java EE多层架构下的大学物理实验系统设计与实现中,我们需要关注几个核心知识点:Java EE技术框架、MVC设计模式、Maven项目管理工具、SSH2框架以及系统架构。 首先,Java EE(Java Platform, Enterprise...

    java+架构系列培训课程_JBOSS_SEAM开发

    ### Java+架构系列培训课程:JBOSS SEAM开发详解 #### 为什么选择JBOSS SEAM?...SEAM和Facelets的结合,不仅提升了Java Web应用的开发效率,还增强了应用的交互性和可维护性,是现代Java EE项目中的关键技术之一。

    《Java EE 5开发基础与实践》第5章课件

    首先,Java Server Faces(JSF)是Sun Microsystems开发的一个MVC(模型-视图-控制器)框架,其设计目标是简化Java Web应用程序的开发。JSF的核心理念是将UI组件与业务逻辑分离,使得开发者可以专注于业务逻辑的实现...

    基于Java EE资产管理系统的设计与实现.zip

    《基于Java EE资产管理系统的设计与实现》是一份深入探讨如何运用Java EE技术构建高效、可靠的资产管理系统的技术文档。本文档详细阐述了系统设计的核心概念、技术选型、架构设计以及实现过程,旨在为读者提供一个...

    JAVA EE教程详解,很详细的

    JAVA EE(Java Platform, Enterprise Edition)是Java技术在企业计算领域的应用平台,它提供了一整套服务、APIs和协议来支持开发、运行大型多层、分布式、可伸缩、可靠和安全网络应用程序。教程通常会介绍Java EE的...

    java开发项目学习

    在“Java开发项目学习”这个主题中,我们可以深入探讨Java编程语言在实际项目中的应用,特别是涉及到了Java的几个核心框架。这些框架是Java开发者在构建复杂应用时的常用工具,能够提高开发效率,增强代码的可维护性...

    Beginning_Java_EE_5_From_Novice_to_Professional-39_beginning jav

    6. **EJB 3.0**:EJB 3.0是Java EE 5中的企业组件模型,简化了Bean的开发。将介绍无状态会话Bean、有状态会话Bean、消息驱动Bean以及Entity Bean的新特性。 7. **JMS(Java Message Service)**:讲解如何使用JMS...

    Thinking in Enterprise Java

    《Thinking in Enterprise Java》是一本深入探讨企业级Java开发的权威著作。这本书旨在帮助开发者理解如何在复杂的商业环境中有效地利用Java技术。以下是对标题和描述中所涉及知识点的详细阐述: 1. **企业级Java...

    方案设计架构图汇总情况-java技术框架.doc

    SmartClient Ajax框架架构专注于创建富客户端应用,利用Ajax技术实现页面的无刷新更新。 Oracle和MySQL是两种广泛应用的关系型数据库管理系统,它们在数据存储、查询优化、事务处理等方面各有特点。 Android架构则...

    基于java的开发源码-版的酒店系统,貌似完整.zip

    本篇文章将深入探讨一个基于Java的酒店管理系统源码,旨在帮助开发者了解如何利用Java技术构建类似的系统。 【描述】:这个酒店系统源码提供了一个完整的开发框架,涵盖了预订、入住、退房等一系列酒店业务流程。...

    java ee电子商城系统课程设计.docx

    - **SSH2集成框架**:SSH2指Struts2、Spring和Hibernate三种技术的集成使用,这是一种广泛应用于Java EE开发的流行架构。其中: - **Struts2**:提供MVC(Model-View-Controller)模型的支持,实现界面、业务逻辑...

Global site tag (gtag.js) - Google Analytics