问题描述
|
我有一个用于审计记录的拦截器,该拦截器基本上设置了两个字段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是拦截器需要知道的状态。有其他替代设计吗?
解决方法
让Servlet过滤器将用户ID存储在ThreadLocal中,然后让拦截器使用它。
,@nathan提出了一种高级方法。如果您想要一个更简单的替代方法,为什么不使用一个通用拦截器,该拦截器基于可审核类的映射(一个合适的委托)进行查找。委托都将共享通用拦截器知道的公共接口。如果避免在通用拦截器中使用状态,则无需担心线程问题。另外,像您当前的方法一样,您可以隔离地对拦截器进行单元测试。