Interceptor接口提供了从会话(session)回调(callback)应用程序(application)的机制, 这种回调机制可以允许应用程序在持久化对象被保存、更新、删除或是加载之前,检查并(或)修改其 属性。一个可能的用途,就是用来跟踪审核(auditing)信息。
Hibernate给我们提供了非常灵活的机制,可以让我们非常容易地做一些共通处理,比如所有表都有同样的字段,可以用同样的方法设值。这时我们没必要在业务处理中每个地方都写上同样的代码。
例如:我们几乎所有的表中都有2个字段:UPDATE_DATETIME和CREATE_DATETIME。分别对应属性名为:updateDatetime和createDatetime。我们需要在修改数据时自动设置updateDatetime,插入数据时自动设置updateDatetime,createDatetime。
我们可以利用Hibernate提供给我们的Interceptor机制实现这个目标。
实现方法:
首先写一个类继承org.hibernate.EmptyInterceptor或者实现org.hibernate.Interceptor接口:
为了简单起见,一般直接继承org.hibernate.EmptyInterceptor就可以了。
然后重载一下onFlushDirty方法和onSave方法就可以了。
因为Hibernate会在更新数据时回调onFlushDirty方法,在插入数据时回调onSave方法。
例:
为了使Hibernate能回调我们的方法,需要在open session时设置:
Session session = SessionFactory.openSession(new MyHibernateInterceptor());
测试代码这里就不介绍了。可以自己写个数据插入/修改的TestCase,看看数据库那2个字段是否被正确地设置了日期。
我们可以利用Hibernate提供给我们的Interceptor机制实现这个目标。
实现方法:
首先写一个类继承org.hibernate.EmptyInterceptor或者实现org.hibernate.Interceptor接口:
为了简单起见,一般直接继承org.hibernate.EmptyInterceptor就可以了。
然后重载一下onFlushDirty方法和onSave方法就可以了。
因为Hibernate会在更新数据时回调onFlushDirty方法,在插入数据时回调onSave方法。
例:
<script src="/images/code/js/shCore.js" type="text/javascript"></script> <script></script> <script src="/images/code/js/shBrushJava.js" type="text/javascript"></script>
- public class MyHibernateInterceptor extends EmptyInterceptor {
- public boolean onFlushDirty(Object entity, Serializable id,
- Object[] currentState, Object[] previousState,
- String[] propertyNames, Type[] types) throws CallbackException {
- try {
- Date updtime = new Date();
- for (int i = 0; i < propertyNames.length; i++) {
- if ("updateDatetime".equals(propertyNames[i])) {
- state[i] = updtime;
- }
- }
- } catch (Exception ex) {
- return false;
- }
- return true;
- }
- public boolean onSave(Object entity, Serializable id, Object[] state,
- String[] propertyNames, Type[] types) throws CallbackException {
- try {
- Date updtime = new Date();
- for (int i = 0; i < propertyNames.length; i++) {
- if ("updateDatetime".equals(propertyNames[i])
- || "createDatetime".equals(propertyNames[i])) {
- state[i] = updtime;
- }
- }
- } catch (Exception ex) {
- return false;
- }
- return true;
- }
- }
public class MyHibernateInterceptor extends EmptyInterceptor {
public boolean onFlushDirty(Object entity, Serializable id,
Object[] currentState, Object[] previousState,
String[] propertyNames, Type[] types) throws CallbackException {
try {
Date updtime = new Date();
for (int i = 0; i < propertyNames.length; i++) {
if ("updateDatetime".equals(propertyNames[i])) {
state[i] = updtime;
}
}
} catch (Exception ex) {
return false;
}
return true;
}
public boolean onSave(Object entity, Serializable id, Object[] state,
String[] propertyNames, Type[] types) throws CallbackException {
try {
Date updtime = new Date();
for (int i = 0; i < propertyNames.length; i++) {
if ("updateDatetime".equals(propertyNames[i])
|| "createDatetime".equals(propertyNames[i])) {
state[i] = updtime;
}
}
} catch (Exception ex) {
return false;
}
return true;
}
}
为了使Hibernate能回调我们的方法,需要在open session时设置:
Session session = SessionFactory.openSession(new MyHibernateInterceptor());
测试代码这里就不介绍了。可以自己写个数据插入/修改的TestCase,看看数据库那2个字段是否被正确地设置了日期。