早些时候,我的拦截器代码在 Hibernate 3 上运行良好。在我升级到 Hibernate 5 并进行必要的更改后,onSave 和 onFlushDirty 等回调方法停止工作。
关于库更改,在 Hibernate 3 jars 下面我用 Hibernate 5 jars 替换。
Hibernate 3个罐子被替换-
- dom4j.jar
- hibernate-core-4.3.5.Final.jar
- hibernate-jpa-2.1-api-1.0.0.Final.jar
- jboss-logging.jar
Hibernate 5 罐添加-
- byte-buddy-1.9.5.jar
- classmate-1.3.4.jar
- dom4j-2.1.1.jar
- hibernate-commons-annotations-5.1.0.Final.jar
- hibernate-core-5.4.1.Final.jar
- javax.persistence-api-2.2.jar
- javax.transaction.jar
- jboss-logging-3.3.2.Final.jar
下面是我的拦截器代码-
public class CustomInterceptor extends EmptyInterceptor {
@Override
public boolean onFlushDirty(Object entity, Serializable id, Object[] currentState, Object[] previousState, String[] propertyNames, Type[] types) {
System.out.println("onFlushDirty called");
return super.onFlushDirty(entity, id, currentState, previousState, propertyNames, types);
}
@Override
public boolean onSave(Object entity, Serializable id, Object[] state, String[] propertyNames, Type[] types) {
System.out.println("onSavecalled");
return super.onSave(entity, id, state, propertyNames, types);
}
}
如果有人可以指出我遗漏的内容或我需要进行的任何更正,那将非常有帮助。
请注意-整个应用程序运行顺利,只是没有调用拦截器回调方法。