现在的位置: 首页 > 综合 > 正文

Hibernate拦截器

2017年11月30日 ⁄ 综合 ⁄ 共 970字 ⁄ 字号 评论关闭

•持久层框架底层的拦截器机制是对诸如Spring等业务管理容器拦截机制的有益补充,使得我们可以在更低层次、更广的对象范围上进行AOP操作(Spring虽然将Hibernate纳入到其容器管理的范围内,但是并没有途径实现对其实体对象的管理)。这样就允许实现某些通用的功能,以及允许对Hibernate功能进行扩展。

•Interceptor接口提供了从会话(session)回调(callback)应用程序(application)的机制, 这种回调机制可以允许应用程序在持久化对象被保存、更新、删除或是加载之前,检查并或修改其属性

•你可以直接实现Interceptor接口,也可以(最好)继承自EmptyInterceptor

•拦截器可以有两种:

–Session范围内的

–SessionFactory范围内的


•使用拦截器时按如下步骤进行:

•(1)定义实现Interceptor接口的拦截器类

•(2)通过Session启用拦截器,或者通过Configuration启用全局拦截器


在Session范围使用自定义的拦截器:

•当使用某个重载的SessionFactory.openSession()使用Interceptor作为参数调用打开一个session的时候,就指定了Session范围内的拦截器。

•Session session = factory.openSession( new AuditInterceptor() );

在SessionFactory范围内使用自定义的拦截器:

•SessionFactory范围内的拦截器要通过Configuration中注册,而这必须在创建SessionFactory之前。在这种情况下,给出的拦截器会被这个SessionFactory所打开的所有

session使用了,除非session打开时明确指明了使用的拦截器。SessionFactory范围内的拦截器,必须是线程安全的,因为多个session可能并发使用这个拦截器,要因此小

心不要保存与session相关的状态

•new Configuration().setInterceptor( new AuditInterceptor() );

转载请注明出处:http://blog.csdn.net/jialinqiang/article/details/8723054

抱歉!评论已关闭.