Java Hibernate 4 JPA EntityListeners在Spring MVC/Spring数据应用程序中未启动

Java Hibernate 4 JPA EntityListeners在Spring MVC/Spring数据应用程序中未启动,java,spring,hibernate,jpa,entitylisteners,Java,Spring,Hibernate,Jpa,Entitylisteners,我有一个Hibernate 4/Spring MVC 3.2.4/Spring Data 1.4.1和Spring安全应用程序,我正在尝试在实体类上集成EventListener。我认为我已经正确配置了所有内容,当我运行单元测试时,我可以看到我的事件侦听器被触发。但是,当我运行完整的MVC应用程序时,事件侦听器从未被触发 我有点不知道在哪里/如何调试这个问题。我的EntityManagerFactory在这两种情况下的设置几乎相同: 制作: <beans profile="tomcat"&

我有一个Hibernate 4/Spring MVC 3.2.4/Spring Data 1.4.1和Spring安全应用程序,我正在尝试在实体类上集成EventListener。我认为我已经正确配置了所有内容,当我运行单元测试时,我可以看到我的事件侦听器被触发。但是,当我运行完整的MVC应用程序时,事件侦听器从未被触发

我有点不知道在哪里/如何调试这个问题。我的
EntityManagerFactory
在这两种情况下的设置几乎相同:

制作:

<beans profile="tomcat">
    <!-- application datasource -->
    <bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean" scope="singleton" lazy-init="true">
        <property name="jndiName" value="java:comp/env/jdbc/josak" />
    </bean>

    <!--  entity manager -->
    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="jpaVendorAdapter" ref="hibernateJpaVendorAdapter"/>
        <property name="packagesToScan" value="com.ia.domain"/>
        <property name="jpaProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
                <prop key="hibernate.query.substitutions">true '1', false '0'</prop>
                <prop key="hibernate.generate_statistics">true</prop>
                <prop key="hibernate.show_sql">false</prop>
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
                <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop>
                <prop key="hibernate.connection.charSet">UTF-8</prop>
            </props>
        </property>

    </bean>
</beans>
如果我在@PrePersist方法中放置断点,我会看到该方法被调用

我的MVC控制器也相当直截了当:

@RequestMapping( method=RequestMethod.GET, value="getUserInfo/{userId}", produces=MediaType.APPLICATION_JSON_VALUE)
@ResponseBody
@PreAuthorize("hasRole('ROLE_PERMISSION_RATE_VIEW')")
@Transactional
public String getUserInfo( @PathVariable long userId ){

    userService.saveUser(createUser());
    return "done";
}
其中
createUser()
只返回一个带有填充字段的新用户对象。然而,我的EventListener中的断点从未被击中,我在日志中也没有看到任何指示它被击中的内容

如果它有帮助,我也可以通过事件侦听器类发布,但我认为它没有多大价值

我的实体类定义为:

@Entity
@EntityListeners( AuditEventListener.class)
public class User {

    @TableGenerator( name="UUIDGenerator", pkColumnValue="user_id", table="uuid_generator", allocationSize=1)
    @Id
    @GeneratedValue(strategy = GenerationType.TABLE, generator="UUIDGenerator")
    @Column(name = "id")
    private Long id;

...
}
我是不是漏掉了什么明显的东西?有没有一个原因可以解释为什么它不是在MVC应用程序中工作的,而是在单元测试中工作的?我的单元测试也使用了完整的Spring上下文配置,因此我对这两种情况之间的区别感到非常困惑


我意识到这是一个非常模糊的问题,但是任何关于如何进一步调试它的指导都将不胜感激。

尽管听起来很悲伤,但我认为我已经将错误归结为jRebel问题。然而,jRebel本身并不存在,我有一个rebel.xml配置文件指向实体的类路径,尽管我希望jRebel从我的webapp类路径加载实体(它们位于两个单独的模块中)。此后,我修改了pom.xml并删除了rebel.xml文件,一切似乎都正常

@RequestMapping( method=RequestMethod.GET, value="getUserInfo/{userId}", produces=MediaType.APPLICATION_JSON_VALUE)
@ResponseBody
@PreAuthorize("hasRole('ROLE_PERMISSION_RATE_VIEW')")
@Transactional
public String getUserInfo( @PathVariable long userId ){

    userService.saveUser(createUser());
    return "done";
}
@Entity
@EntityListeners( AuditEventListener.class)
public class User {

    @TableGenerator( name="UUIDGenerator", pkColumnValue="user_id", table="uuid_generator", allocationSize=1)
    @Id
    @GeneratedValue(strategy = GenerationType.TABLE, generator="UUIDGenerator")
    @Column(name = "id")
    private Long id;

...
}