データ アクセス レイヤーで Hibernate を使用して JPA-2.0 を使用しています。
監査ログの目的で、persistence.xml で以下のプロパティを構成することにより、Hibernate の EmptyInterceptor を使用しています。
<property name="hibernate.ejb.interceptor"
value="com.mycom.audit.AuditLogInterceptor" />
AuditLogInterceptorは hibernate の ' org.hibernate.EmptyInterceptor 'を拡張します。
public class AuditLogInterceptor extends EmptyInterceptor {
private Long userId;
public AuditLogInterceptor() {}
@Override
public boolean onSave(Object entity, Serializable id, Object[] state,
String[] propertyNames, Type[] types) throws CallbackException {
// Need to perform database operations using JPA entity manager
return false;
}
@Override
public boolean onFlushDirty(Object entity, Serializable id,
Object[] currentState, Object[] previousState,
String[] propertyNames, Type[] types) {
// other code here
return false;
}
@Override
public void postFlush(Iterator iterator) throws CallbackException {
System.out.println("I am on postFlush");
// other code here
}
}
データベース操作を実行するために、データ アクセス レイヤーで JPA エンティティ マネージャーを使用しています。JPA の設定は以下のようになります。
<bean id="entityManagerFactory"
class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
p:persistenceUnitName="PersistenceUnit"
p:persistenceXmlLocation="classpath*:persistence.xml"
p:dataSource-ref="dataSource" p:jpaVendorAdapter-ref="jpaAdapter">
<property name="loadTimeWeaver">
<bean
class="org.springframework.instrument.classloading.InstrumentationLoadTimeWeaver" />
</property>
</bean>
私のAbstractDAOは次のとおりです。
public class AbstractDao<T, ID extends Serializable> {
private final transient Class<T> persistentClass;
protected transient EntityManager entityManager;
@SuppressWarnings("unchecked")
public AbstractDao() {
this.persistentClass = (Class<T>) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
}
@PersistenceContext
public final void setEntityManager(final EntityManager entityMgrToSet) {
this.entityManager = entityMgrToSet;
}
public final Class<T> getPersistentClass() {
return persistentClass;
}
public final void persist(final T entity) {
entityManager.persist(entity);
}
}
「AuditLogInterceptor」に JPA エンティティ マネージャーを挿入して、抽象的な DAO のように「AuditLogInterceptor」でデータベース操作を実行できるようにしたいと考えています。
何か案が?適切な解決策は何ですか?