什么是SSH
SSH是 struts+spring+hibernate的一个集成框架,是目前较流行的一种web应用程序开源框架。SSH不是一个框架,而是把多个框架(Struts、Spring以及Hibernate)紧密的结合在一起,用于构建灵活、易于扩展的多层Web应用程序。
SSH框架的系统从职责上分为四层:表示层、业务逻辑层、数据持久层和域模块层(实体层)。
SSH(Struts2+Spring+Hibernate)框架的项目,该架构主要分为三个层次:
(1)Struts2:负责web层
(2)Spring:业务层的管理
(3)Hibernate:负责数据持久化
Struts2工作原理:
1.初始化一个指向servlet容器的请求。
2.请求经过web.xml中配置的过滤器过滤,FilterDispatcher(struts2控制器的核心)询问ActionMapper是否需要调用某个Action来处理这个请求。如果ActionMapper决定需要调用某个Action,FilterDispatcher则把请求的处理交给ActionProxy。
3.ActionProxy通过配置文件Struts.xml配置文件找到需要调用的Action类。
4.ActionProxy创建一个ActionInvocation实例,同时ActionInvocation通过代理模式调用Action。但在调用之前,ActionInvocation会根据配置加载Action相关的所有Interceptor(拦截器)。
5.Action执行完毕后,ActionInvocation负责根据struts.xml中的配置找到对应的返回结果result。
即开发人员通过发送http请求,这个请求经过web.xml的过滤器过滤看看是否要调用某个action,如果有则在Struts.xml找到该请求的实现的方法,然后返回运行的结果。
Hibernate工作原理:
1. 读取并解析配置文件
2.读取并解析映射信息,创建SessionFactory
3. 打开Sesssion
4.创建事务Transation
5. 持久化操作
6.提交事务
7.关闭Session
8. 关闭SesstionFactory
即通过spring管理的Hibernate初始化时加载了xxx.hbm.xml然后读取解析映射信息,创建了SessionFactory。然后打开session,通过session对事物进行操作并提交。最后关闭session,关闭SessionFactory。
Hibernate中bean 的三种状态
Hibernate对象分为三种状态:瞬时态(new 出来的或者实例化时session无关的),持久态(session关联)与游离态(曾经与session关联)。其中持久态的对象是PO,瞬时态、托管态的对象可作为VO。(PO不应该直接用作v层)所以在使用中应该注意三态的转化。
如:
在进行数据操作的一系列过程中,save或者saveorupdate操作可以把瞬时态或者游离态的对象转换成持久态,而delete或者session的close、flush等操作将会把session相关联的持久态对象转换成游离态。
Hibernate对象的状态和生命周期
使用new操作符初始化的对象是一个瞬时态的(Transient)(没有任何跟数据库表相关联的行为,只要应用不再引用这些对象,它们的状态就会丢失,并由垃圾回收机制回收);
瞬时态对象经过save(),saveOrUpdate会转换成持久态,由session统一管理,持久态对象的操作与数据库同步;
持久态对象经过evict(),close(),clear()等会转换成游离态,这时虽然被持久化,但是不在session缓存中,通过lock(),update(),saveOrUpdate又会转换成持久态。 通过get(),load(),find(),iterate()获得的对象直接就是持久态的。
Spring的工作原理:
在SSH框架中spring充当了管理容器的角色。我们都知道Hibernate用来做持久层,因为它将JDBC做了一个良好的封装,程序员在与数据库进行交互时可以不用书写大量的SQL语句。Struts是用来做应用层的,它负责调用业务逻辑serivce层。
所以SSH框架的流程大致是:Jsp页面----Struts------Service(业务逻辑处理类)---Hibernate(左到右)
struts负责控制Service(业务逻辑处理类),从而控制了Service的生命周期,这样层与层之间的依赖很强,属于耦合。
这时,使用spring框架就起到了控制Action对象(Strus中的)和Service类的作用,两者之间的关系就松散了,Spring的Ioc机制(控制反转和依赖注入)正是用在此处。
控制反转:就是由容器控制程序之间的(依赖)关系,而非传统实现中,由程序代码直接操控。
依赖注入:组件之间的依赖关系由容器在运行期决定 ,由容器动态的将某种依赖关系注入到组件之中。
使用Spring的第二个好处(AOP应用):
事务的处理:
在以往的JDBCTemplate 中事务提交成功,异常处理都是通过Try/Catch 来完成。Spring容器集成了TransactionTemplate,它封装了所有对事务处理的功能,包括异常时事务回滚,操作成功时数据提交等复杂业务功能。这都是由Spring 容器来管理,大大减少了程序员的代码量,也对事务有了很好的管理控制。Hibernate中也有对事务的管理,hibernate 中事务管理是通过SessionFactory 创建和维护Session 来完成。而Spring 对SessionFactory配置也进行了整合,不需要在通过hibernate.cfg.xml来对SessionaFactory进行设定。
这样的话就可以很好的利用Sping对事务管理强大功能。
避免了每次对数据操作都要现获得Session实例来启动事务/提交/回滚事务还有繁琐的Try/Catch操作。
这些也就是Spring中的AOP(面向切面编程)机制很好的应用。一方面使开发业务逻辑更清晰、专业分工更加容易进行。
另一方面就是应用Spirng AOP隔离降低了程序的耦合性使我们可以在不同的应用中将各个切面结合起来使用大大提高了代码重用度。
希望以上整理的内容能够帮助到大家,感谢大家对小牛知识库的支持。
本文向大家介绍详解Python 定时框架 Apscheduler原理及安装过程,包括了详解Python 定时框架 Apscheduler原理及安装过程的使用技巧和注意事项,需要的朋友参考一下 在我们的日常工作自动化测试当中,几乎超过一半的功能都需要利用定时的任务来推动触发,例如在我们项目中有一个定时监控模块,根据自己设置的频率定时跑测试用例,定时检测是否存在线上紧急任务等等,这些都涉及到了有关定时
本文向大家介绍详解SSH框架和Redis的整合,包括了详解SSH框架和Redis的整合的使用技巧和注意事项,需要的朋友参考一下 一个已有的Struts+Spring+Hibernate项目,以前使用MySQL数据库,现在想把Redis也整合进去。 1. 相关Jar文件 下载并导入以下3个Jar文件: commons-pool2-2.4.2.jar、jedis-2.3.1.jar、spring-da
本文向大家介绍thinkphp5框架路由原理与用法详解,包括了thinkphp5框架路由原理与用法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了thinkphp5框架路由原理与用法。分享给大家供大家参考,具体如下: 路由理解 概括的说:路由就是网络请求的url与thinkphp应用层的逻辑处理地址的对应关系。 通俗的说:路由就是把url的请求优雅的对应到你想要执行的操作方法。 路由其
本文向大家介绍Mybatis框架及原理实例分析,包括了Mybatis框架及原理实例分析的使用技巧和注意事项,需要的朋友参考一下 摘要 本篇文章只是个人阅读mybatis源码总结的经验或者个人理解mybatis的基本轮廓,作为抛砖引玉的功能,希望对你有帮助,如果需要深入了解细节还需亲自去阅读源码。 mybatis基本架构 mybatis的源码应该算是比较容易阅读的,首先mybatis核心功能就是执行
Xwindow 使用服务器-客户端架构。无论本地图形界面,还是远程图形界面,都以同样的流程工作。这样便不需要分别进行设计和维护。 本地X客户端 ┐ ┌ 键盘 远程X客户端 ┼ X协议 ─ X服务器 ─ 驱动程序┼ 鼠标 远程X客户端 ┘ └ 显示器 Xserver Xwindow 系统服务器端,通过驱动程序(硬件规范)来管理硬件资源。 例如:当我们移动鼠标时,通过驱动程序[窗口
本文向大家介绍ThinkPHP框架设计及扩展详解,包括了ThinkPHP框架设计及扩展详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP框架是国内知名度很高应用很广泛的php框架,我们从一些简单的开发示例中来深入了解一下这个框架给我们带来的开发便捷性,以及游刃有余的扩展设计。同时也从源码分析的角度看看框架的一些不足,尽量做全面客观的评价。这里假设大家已经使用过ThinkPHP框架,基本