关于SSH与SSM的组成及其区别

痴心易碎 提交于 2019-11-28 08:05:12

前言

  当下SpringBoot盛行,咱再聊聊SpringBoot盛行之前的框架组合,当做复习巩固哈。

  在聊之前,得先说说MVC,MVC全名是Model View Controller,是模型(model)--视图(view)--控制器(controller)的缩写。M是指业务模型,V是指用户界面,C则是控制器。

  一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。

  本人是在学校的时候学过SSH和SSM,并用该框架组合做了几个私单,算是给大学生活餐加点外快吧,哈哈

一、SSH和SSM的定义:

  SSH:指的是Struts2(做前端控制器),Spring(管理各层的组件),Hibernate(负责持久化层)

  SSM:指的是SpringMVC(做前端控制器),Spring(管理各层的组件),Mybatis(负责持久化层)

二、SSH和SSM的实现原理:

  

  1、Struts2的原理:  

  Struts2框架执行过程:

  1)、客户端初始化一个指向Servlet容器(例如tomcat)的请求;

  2)、这个请求经过一系列的过滤器(Filter),这些过滤器中有一个叫做ActionContextCleanUp的可选过滤器,这个过滤器对于Struts2和其他框架的集成很有帮助,例如:SiteMesh Plugin

  3)、接着FilterDispatcher被调用,FilterDispatcher询问ActionMapper来决定这个请求是否需要调用某个Action,FilterDispatcher是控制器的核心,就是mvc中c控制层的核心

  4)、如果ActionMapper决定需要调用某个Action,FilterDispatcher会把请求的处理交给ActionProxy;

  5)、ActionProxy通过Configuration Manager询问框架的配置文件,找到需要调用的Action类;

  6)、ActionProxy创建一个ActionInvocation的实例;

  7)、ActionInvocation实例使用命名模式来调用,在调用Action的过程前后,会涉及到相关拦截器(Intercepter) 的调用;

  8)、一旦Action执行完毕,ActionInvocation负责根据struts.xml中的配置找到对应的返回结果。返回结果通常是一个需要被表示的JSP或者FreeMarker的模板;

  9)、将处理结果返回给客户端。

  2、SpringMVC的原理:

  SpringMVC框架执行过程:

  1)、客户端发出一个http请求给web服务器,web服务器对http请求进行解析,如果匹配DispatcherServlet的请求映射路径(在web.xml中指定),web容器将请求转交给DispatcherServlet;

  2)、DispatcherServlet接收到这个请求之后将根据请求的信息(包括URL、Http方法、请求报文头和请求参数Cookie等)以及HandlerMapping的配置找到处理请求的处理器(Handler)

  3)、DispatcherServlet根据HandlerMapping找到对应的Handler,并返回;

  4)、将处理权交给Handler(Handler将具体的处理进行封装),再由具体的处理器适配器(HandlerAdapter)对Handler进行具体的调用;

  5)、处理器适配器执行Handler;

  6)、Handler对数据处理完成以后将返回一个ModelAndView对象给处理器适配器;

  7)、处理器适配器向前端控制器返回ModelAndView(ModelAndView是SpringMVC框架的一个底层对象,包括Model和View);

  8)、Handler返回的ModelAndView只是一个逻辑视图,并不是一个正式的视图,前端控制器请求视图解析器(ViewResolver)去进行视图解析,根据逻辑视图名解析成真正的视图(jsp);

  9)、视图解析器向前端控制器返回View;

  10)、前端控制器进行视图渲染,视图渲染将模型数据(在ModelAndView对象中)填充到request域中;

  11)、前端控制器向用户响应结果。

  3、Hibernate的原理:

 

  Hibernate框架执行过程:

  1)、通过Configuration().configure();读取并解析hibernate.cfg.xml配置文件;

  2)、由hibernate.cfg.xml中的读取并解析映射信息;

  3)、通过config.buildSessionFactory(); //创建SessionFactory

  4)、sessionFactory.openSession();  //打开Session

  5)、session.beginTransaction();  //创建事务Transaction

  6)、persistent operate持久化操作;

  7)、session.getTransaction().commit();  //提交事务

  8)、关闭Session;

  9)、关闭SessionFactory;

  4、Mybatis原理:

  Mybatis框架执行过程:

  1)、配置Mybatis的配置文件,SqlMapConfig.xml(名称不固定)

  2)、通过配置文件,加载Mybatis运行环境,创建SqlSessionFactory会话工厂SqlSessionFactory在实际使用时按单例方式;

  3)、通过SqlSessionFactory创建SqlSession,SqlSession是一个面向用户接口(提供操作数据库方法),实现对象是线程不安全的,建议sqlSession应用场合在方法体内;

  4)、调用SqlSession的方法去操作数据。如果需要提交事务,需要执行SqlSession的commit()方法;

  5)、释放资源,关闭SqlSession。

  4、Spring家族:

三、对比:

  1、Struts2与SpringMVC两种框架对比:

  1)不同之处:

    ①、springmvc和struts2都是负责去转发的,但是两者针对request的请求上面区别很大。

      springmvc是针对于方法级别的请求,也就是一个方法对应于一个请求,属于方法拦截,请求的数据方法不共享;而struts2则时针对一个Action类来进行请求的,即一个Action类对应于一个请求,所以类拦截,请求的数据类共享;

    ②、springmvc入口是一个servlet前端控制器(DispatcherServlet),struts2入口是一个filter过滤器;

    ③、springmvc的配置文件相对struts2来说较为少,容易上手,可以加快软件开发的速度。

  2、Hibernate和Mybatis两种框架对比:

  1)、相同之处:

    ①:Hibernate与Mybatis都可以是通过SessionFactoryBuilder,由XML配置文件生成SessionFactory,然后由SessionFactory生成Session,最后由Session来开启执行事务和SQL语句。其中SessionFactoryBuilder,SessionFactory,Session的生命周期都是差不多的;

    ②、Hibernate和Mybatis都支持JDBC和JTA事务处理。

  2)、不同之处:

    ①、Hibernate是一种O/R关系型,即完成数据库表和持久化类之间的映射,而Mybatis是针对的SQL-Mapping,个人理解是一种Hibernate把数据库给封装好以后,可以调用相应的数据库操作语句HQL,而Mybatis则是用的原始的数据库操作语句;

    ②、针对高级查询,Mybatis需要手动编写SQL语句,以及ResultMap。而Hibernate有良好的映射机制,开发者无需关心SQL的生成与结果映射,可以更专注于业务流程;

    ③、Hibernate优化起来相对Mybatis较难,而且Hibernate掌握起来相对Mybatis较难,但是Hibernate数据库移植性很好,Mybatis的数据库移植性不好,不同的数据库需要写不同SQL。

四、总结:

  SSM和SSH相同之处在于都是用Spring依赖注入DI来管理各层的组件,并且都是使用面向切面编程AOP来管理事务、日志、权限等。不同之处在于MVC实现方式,以及ORM持久化方面不同(Hibernate与Mybatis)。SSM越来越轻量级配置,将注解开发发挥到极致,且ORM实现更加灵活,SQL优化更简便;而SSH较注重配置开发,其中的Hibernate对JDBC的完整封装更面向对象,对增删改查的数据维护更自动化,但SQL优化方面较弱,且入门门槛稍高。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!