您的位置:首页>>资讯中心>>学习园地

JavaWeb的架构的演变


在java架构模式中,可以将MVC架构模式抽象为以下结构:

     1.View层。View表示视图层,可采用的技术如JSP,Structs,SpringMVC等

     2.Controller层。Controller表示控制器层,可采用的技术,如Servlet/Filter,Spring等

     3.Service层。Service层表示核心服务层,向架构上层提供服务

     4.DAO层。DAO层表示数据访问层,可采用的技术如jdbc和ORM框架

     5.Model层。Model层即表示JavaBean对象

     6.Utilities层。Utilities层表示公共工具层

       需要注意的是,在该架构抽象模型中,并未涉及到其他技术,如SOA,Nosql(Redis,Mongodb等),MQ等,

除此之外,基于Springboot+Cloud的微服务技术,也未涉及,因为这里只将基于MVC的架构模式演变,具体

的JavaWeb架构,将在以后的章节讲解。


image.png


基于如上的架构抽象模型,还可以将该架构模式发展分为三个阶段:

         阶段一:Servlet阶段

         阶段二:SSH(Spring+Structs+Hibernate)阶段

         阶段三:SSM阶段(Spring+SpringMVC+Mybatis)阶段

         其实,还存在阶段四,即微服务阶段,本文不详细讲解。

     (一)阶段一:Servlet/Filter扮演控制器角色

        1.在该阶段架构模式中,Servlet/Filter扮演Controller角色,JSP扮演View角色,JavaBean扮演Model角色

        2.该阶段的数据库访问技术为具体DB的jdbc 

        该模式虽然实现了所谓的MVC模式,但却存在诸多问题:

      (1)前后端分离不彻底。由于JSP技术前后端分离不彻底,开发人员往往会在JSP页面中嵌套Java代码,从而需要前端开发人员懂java技术

      (2)JSP页面可读性差,编写效率低,尽管引入EL,JSTL等技术

      (3)Sevlet/Filter作为控制器,面临的稳定性,安全性考验(Servlet是线程不安全的)等

      (4)数据库访问技术采用传统的jdbc,造成过多的冗余代码。当然,还存在很多问题,这里不一一列举,为了解决这些问题,JavaWeb专家们提出了一种架构思想:模块化,抽象化和专一化的思想。基于该思想

,涌向出一批专业化开源框架,其中较为出名的组合框架便是SSH了。


image.png


(二)阶段二:SSH

    1.在该架构模式中,Controller采用Spring框架技术,View采用Structs框架技术,DB访问技术采用Hibernate框架技术

    2.从SSH中,很容易看出前后端出现了专业化,精细化分工,且朝框架演变,如前端框架采用Structs,后端框架采用Spring等。然而,SSH架构模式虽然解决了Servlet/Filter架构模式存在的问题,实现了专业化、精细化分工,实现了模块化和抽象化,但其却存在一个比较大的问题:框架笨重不灵活。如Hibernate虽然能满足业务需求,能解决业务,但其笨重不灵活,不能很好地实现可配置化的灵活方式,Structs也过于笨重。为了解决该问题,JavaWeb专家们又提出了另外一种架构模式,即SSM架构模式。


 image.png


(三)阶段三:SSM

      1.该模式中,Spring扮演Controller角色,SpringMVC扮演View角色(当然,小型系统,可直接采用SpringMVC即可),Mybatis扮演DB访问技术

      SSM架构模式,在当前的JavaEE中,算是比较流行的开发模式了,也是大都数企业的技术选型之一。当然,能与SSM相媲美的另一种设计思想,那就是微服务思想(SpringBoot+cloud技术等),本文不谈及微服务。


image.png


上一篇: JavaScript闭包函数

下一篇: Java程序员必备的15个框架