Hibernate Envers条件审计,在运行时忽略自定义EnversIntegrator

时间:2015-02-15 16:51:38

标签: java spring hibernate jpa hibernate-envers

我需要使用Hibernate Envers和Spring配置条件审计。

默认配置有效,但我只想审核删除操作,将已删除的实体保存在审计表中。

我跟着all the documentation steps但是当我尝试使用创建和删除实体的简单主程序时,我的CustomEnversIntegrator不会被调用,而是调用org.hibernate.envers.event.spi.EnversIntegrator被称为。

这是我的spring-config.xml:

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="jpaProperties">
        <props>
            <prop key="org.hibernate.envers.default_schema">macap_auditoria</prop>
            <prop key="org.hibernate.envers.audit_table_prefix">aud_</prop>
            <prop key="org.hibernate.envers.audit_table_suffix"></prop>
            <prop key="org.hibernate.envers.store_data_at_delete">true</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
            <prop key="hibernate.listeners.envers.autoRegister">false</prop>
            <prop key="org.hibernate.envers.cascade_delete_revision">true</prop>
        </props>
    </property>
    ......

CustomEnversIntegrator.java,只监听删除操作:

    public class CustomEnversIntegrator extends EnversIntegrator {

private AuditConfiguration enversConfiguration;

@Override
public void integrate(Configuration configuration, SessionFactoryImplementor sessionFactory, SessionFactoryServiceRegistry serviceRegistry) {
    final EventListenerRegistry listenerRegistry = serviceRegistry.getService(EventListenerRegistry.class);
    listenerRegistry.addDuplicationStrategy(EnversListenerDuplicationStrategy.INSTANCE);
    enversConfiguration = AuditConfiguration.getFor(configuration, serviceRegistry.getService(ClassLoaderService.class));
    if (enversConfiguration.getEntCfg().hasAuditedEntities()) {
        listenerRegistry.prependListeners(EventType.POST_DELETE, new CustomEnversPostDeleteEventListener(enversConfiguration));
    }
}

}

最后,我添加了文件META-INF / services / org.hibernate.spi.Integrator 内置一行:uy.com.macap.ccd.services.persistence.audit.CustomEnversIntegrator

我的.m2文件夹中生成的jar包含里面的META-INF / services / org.hibernate.spi.Integrator文件,所以我不知道除了使用修改后的EnversIntegrator类重新编译envers之外还要尝试什么。我

感谢。

1 个答案:

答案 0 :(得分:2)

我认为问题是META-INF / services下的文件名称:

根据文档,它应该是false

而不是

org.hibernate.integrator.spi.Integrator