架构学习(一):浅析Java中的Model1和Model2

Java的动态Web编程,经历了所谓的Model1和Model 2时代。

(动态Web编程技术的发展历史)

Model1

JSP页面是中心

JSP页面接收处理客户端请求,对请求处理后直接做出响应,这样就在JSP页面中同时实现了业务逻辑和流程控制。

上图中的“业务逻辑”对应下图的JavaBean,完成业务处理和访问数据库。

优点和不足

实现比较简单,适用于快速开发小规模项目。

难和简单都是相对的,如果采用Model2的话至少得多一个Servlet类。

但JSP页面身兼View和Controller两种角色,将控制逻辑和表现逻辑混杂在一起,从而导致代码的重用性非常低,增加了应用的扩展性和维护的难度。

也就是说职责过多,耦合度高,很难适应变化。比如老式显卡都是集成在主板上的,显卡要是坏了,那就换主机吧,悲剧。

Model2

职责划分,简化JSP工作量

model2在model1基础上,对jsp功能进行了职责划分。

Servlet的加入,从而构成了MVC的实现。

Servlet做控制器(Controler):

    取得参数调用业务逻辑转向页面

业务逻辑做模型(Model):

    处理业务逻辑保存数据状态

JSP做视图(View),渲染页面。

上图中的“业务逻辑”对应下图的JavaBean,完成业务处理和访问数据库。

继续职责划分,加入三层思想

将业务逻辑模型(Model)进一步划分成业务逻辑和持久化数据

Servlet/JSP对应三层中的UI(显示层)

业务逻辑对应BLL(业务逻辑层)

持久化逻辑对应DAL(数据访问层)

优点和不足

职责划分的更细了,就像现在的显卡大都是独立的。如果显卡坏了或者要升级,换一个相同规格的就好了。

但带来好处的同时,工作量大了,还没开始干活就得先制定好规范,比如主板和显卡的共同的接口是MMDK#**#8型号,在没生产之前,就得花费时间商量出一套公认的准则。

小结

如果项目较小,需求较稳定,不准备升级,可以采用Model1模型,能够低成本,较快速的开发。

如果项目较大,需求不定,以后还可能升级,可以采用Model2模型,虽然成本较高,工作量较大,磨刀不误砍柴工,应对变化,未雨绸缪才是。

各有所长,在适当条件下做出适当的选择就是最优的。

一直觉得人应该去旅行,在年轻的时候,

架构学习(一):浅析Java中的Model1和Model2

相关文章:

你感兴趣的文章:

标签云: