浅谈JavaWeb架构演变
一 javaweb架构演变
在java架构模式中,我们可以将mvc架构模式抽象为如下结构:
1.view层。view层即ui层,可采用的技术如jsp,structs,springmvc等
2.controller层。controller表示控制器层,可采用的技术,如servlet/filter,spring等
3.service层。service层表示核心服务层,向架构上层提供服务
4.dao层。dao层表示数据访问层,可采用的技术如jdbc和orm框架(如spring jdbc,jpa,hibernate,mybatis等)
5.model层。model层即表示javabean对象
6.utilities层。utilities层表示公共工具层
需要注意的是,在该架构抽象模型中,并未涉及到其他技术,如soa,nosql(redis,mongodb等),mq等,
除此之外,基于springboot+cloud的微服务技术,也未涉及,因为这里只将基于mvc的架构模式演变,具体
的javaweb架构,将在以后的章节讲解。
基于如上的架构抽象模型,我们可以将该架构模式发展分为三个阶段:
阶段一: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了。
(二)阶段二:ssh
1.在该架构模式中,controller采用spring框架技术,view采用structs框架技术,db访问技术采用hibernate框架技术
2.从ssh中,很容易看出前后端出现了专业化,精细化分工,且朝框架演变,如前端框架采用structs,后端框架采用spring等
然而,ssh架构模式虽然解决了servlet/filter架构模式存在的问题,实现了专业化、精细化分工,实现了模块化和抽象化,
但其却存在一个比较大的问题:框架笨重不灵活。如hibernate虽然能满足业务需求,能解决业务,但其笨重不灵活,不能很好地
实现可配置化的灵活方式,structs也过于笨重。为了解决该问题,javaweb专家们又提出了另外一种架构模式,即ssm架构模式。
(三)阶段三:ssm
1.该模式中,spring扮演controller角色,springmvc扮演view角色(当然,小型系统,可直接采用springmvc即可),mybatis扮演db访问技术
ssm架构模式,在当前的javaee中,算是比较流行的开发模式了,也是大都数企业的技术选型之一。当然,能与ssm相媲美的另一种设计
思想,那就是微服务思想(springboot+cloud技术等),本篇文章不谈及微服务。
二 ssm核心框架概述
(一)spring框架
spring框架目前是javaweb开发的主流框架,也可以说是诸多企业的必选框架,它大致包括六大模块。
1.spring核心容器。该容器是spring框架最核心部分,它管理着spring运用中bean的创建、配置和管理等
2.spring aop。该模块为面向切面和di(依赖注入)提供了很好的支持
3.数据库访问与集成模块
4.web与远程调用技术
5.instrument模块
6.test模块
(二) mybatis框架
1.根据mybatis源码,将其抽象为三层:基础支持层,核心处理层和接口层
2.基础支持层包括:数据源、事务管理、日志、类型转换、缓存、bind、解析器等
3.核心处理层包括:配置解析、配置映射、sql解析、sql执行、结果集映射、插件等
4.接口层主要提供java api
三 版权区
感谢您的阅读,若有不足之处,欢迎指教,共同学习、共同进步。
博主网址:http://www.cnblogs.com/wangjiming/。
极少部分文章利用读书、参考、引用、抄袭、复制和粘贴等多种方式整合而成的,大部分为原创。
如您喜欢,麻烦推荐一下;如您有新想法,欢迎提出,邮箱:2098469527@qq.com。
可以转载该博客,但必须著名博客来源。
上一篇: Spring Boot使用AOP在控制台打印请求、响应信息
下一篇: C++基础知识(1)