我有一个审计日志拦截器,基本上设置了两个字段modified_by和created_by。例如,
public void update(DomainEntity entity, Integer userId) {
template.update(audited(entity, userId));
}
private DomainEntity audited(DomainEntity entity, Integer userId) {
template.setEntityInterceptor(new AuditInterceptor(userId));
return entity;
}
因此,我使用有问题的userId创建一个新的Interceptor,并在模板上为每个可审计的DAO操作设置它。我担心她有一个并发问题,因为两个线程可能会在同一个模板上设置拦截器,弄乱了。
避免这种情况的最佳解决方案是什么? userId是拦截器需要知道的状态。任何替代设计?
答案 0 :(得分:1)
让servlet过滤器将用户ID存储在ThreadLocal中,让拦截器使用它。
答案 1 :(得分:1)
@nathan提出了一种先进的方法。如果你想要一个更简单的替代方案,为什么不能有一个基于可审计类Map的查找的通用拦截器,一个合适的委托。代表们将共享通用拦截器知道的通用接口。如果在通用拦截器中避免使用状态,则不存在线程问题。此外,与您当前的方法一样,您可以单独对拦截器进行单元测试。