我目前正在努力让 Spring Data JPA 审计工作,它目前没有设置字段,并且在使用实体时似乎没有以任何方式被调用。特别是对它如何与持久实体的标准流挂钩的任何见解都会有所帮助。
我目前正在使用 Spring Data JPA 1.5.0.M1 和 Spring 3.2.6,审计部分的基本配置是:
@Configuration
@EnableJpaAuditing(auditorAwareRef = "auditorAware")
@EnableJpaRepositories(basePackages = "org.myproject.dao")
@EnableTransactionManagement
public class JpaConfig {
...}
Run Code Online (Sandbox Code Playgroud)
在尝试解决此问题时,当前的相关实体用注释和界面进行了标记(注释将是首选)。我意识到不应该这样做,但我暂时复制并粘贴了。
@Entity
public class AutoDraft implements Auditable<Long, Long> {
@SequenceGenerator(name="seq_auto_draft", sequenceName="SEQ_AUTO_DRAFT")
@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="seq_auto_draft")
@Id
private Long id;
@CreatedDate
@Type(type="org.jadira.usertype.dateandtime.joda.PersistentDateTime")
private DateTime createdDate;
@LastModifiedDate
@Type(type="org.jadira.usertype.dateandtime.joda.PersistentDateTime")
private DateTime lastModifiedDate;
Run Code Online (Sandbox Code Playgroud)
在日志中,正在设置相关的 bean,我可以在启动时捕获在 AuditingEntityListener 中正确配置的 AuditingHandler,但在运行时似乎没有触发任何内容,也没有与特定实体或存储库关联的任何与审计相关的日志消息。我的注意力目前被 AuditingBeanFactoryPostProcessor 吸引,但我已经在这方面花费了太长时间,因此可以使用任何帮助。
我知道这是一个老问题,但我遇到了同样的问题,评论帮助我解决了它。所以我想如果有人再次遇到这个问题,我会说得更清楚。
Spring Data 的文档有点误导,因为它暗示您可以通过@Configuration使用@EnableJpaAuditing.
但是,我发现不清楚的部分是您仍然需要修改 orm.xml 文件(https://docs.spring.io/spring-data/jpa/docs/current/reference/html/#auditing):
<persistence-unit-metadata>
<persistence-unit-defaults>
<entity-listeners>
<entity-listener class="….data.jpa.domain.support.AuditingEntityListener" />
</entity-listeners>
</persistence-unit-defaults>
Run Code Online (Sandbox Code Playgroud)
但是,如果您使用的是纯基于注释的解决方案,则您可能没有 orm.xml 文件。正如 Matt Whipple 在评论中指出的那样,您必须向@EntityListeners实体类添加注释,以便 JPA 持久性库在持久化对象时调用 Spring 审计类(反过来处理审计)。
所以一个完整的例子可能是这样的:
@Configuration
@EnableJpaAuditing
@PropertySource({ "application.properties" })
public class AppConfig {
/**
* Stubbed method for the auditor as the app does not concern itself with auditing any User fields
* Consequently, return null for the current auditor
* @return
*/
@Bean
public AuditorAware<User> auditorProvider(){
return new AuditorAware<User>() {
@Override
public User getCurrentAuditor() {
return <User object that is Logged In>;
}
};
}
}
Run Code Online (Sandbox Code Playgroud)
然后在您的实体上:
@Entity
@EntityListeners(AuditingEntityListener.class)
public class Log {
@Id
@GeneratedValue
private long id;
@CreatedDate
@Column(nullable=false)
private Date createdOn;
// bunch of other audit fields (and other fields)
...
...
}
Run Code Online (Sandbox Code Playgroud)
看来您忘记了配置AuditingEntityListener(orm.xml这仍然是必要的)。将此行添加到您的orm.xml:
<persistence-unit-metadata>\n <persistence-unit-defaults>\n <entity-listeners>\n <entity-listener class="\xe2\x80\xa6.data.jpa.domain.support.AuditingEntityListener" />\n </entity-listeners>\n </persistence-unit-defaults>\n</persistence-unit-metadata>\nRun Code Online (Sandbox Code Playgroud)\n\n\n
| 归档时间: |
|
| 查看次数: |
3862 次 |
| 最近记录: |