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

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

    架构学习(一):浅析Java中的Model1和Model2_第1张图片

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

Model1

JSP页面是中心

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

架构学习(一):浅析Java中的Model1和Model2_第2张图片

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

架构学习(一):浅析Java中的Model1和Model2_第3张图片

 

优点和不足

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

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

 

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

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

 

 

Model2

职责划分,简化JSP工作量

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

 

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

  • Servlet做控制器(Controler):
    1. 取得参数
    2. 调用业务逻辑
    3. 转向页面
  • 业务逻辑做模型(Model):
    1. 处理业务逻辑
    2. 保存数据状态
  • JSP做视图(View),渲染页面。

 

架构学习(一):浅析Java中的Model1和Model2_第4张图片

 

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

架构学习(一):浅析Java中的Model1和Model2_第5张图片

 

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

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

架构学习(一):浅析Java中的Model1和Model2_第6张图片

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

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

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

 

 

优点和不足

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

 

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

 

 

小结

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

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

 

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

你可能感兴趣的:(java,jsp,servlet,model2,三层架构)