你可以,但我会使用一个简单的 POJO 来保持干净分离。请记住,存储在单例中的值只能由处理 servlet 请求的同一线程访问,因此,如果您正在执行任何异步操作,则需要考虑这一点。这是一个超级基本的实现:
public class OrgId {
public static ThreadLocal<Integer> orgId = new ThreadLocal<Integer>();
}
由于组织 ID 驻留在会话中,您可以像这样在早期的 servlet 过滤器中设置 ThreadLocal 的值(没有太多错误检查):
public class OrgIdFilter implements Filter {
public void doFilter(ServletRequest servletrequest, ServletResponse servletresponse, FilterChain filterchain) throws java.io.IOException, javax.servlet.ServletException {
int orgId = 0;
HttpServletRequest req = (HttpServletRequest) servletRequest;
HttpSession session = req.getSession();
orgId = Integer.parseInt(session.getAttribute("OrganizationalIdAttr"));
try {
OrgId.orgId.set(orgId);
filterChain.doFilter(servletRequest, servletresponse);
} finally {
OrgId.orgId.set(null); // Important to clear after request !!
}
}
}
这假设在调用过滤器时 orgId 在会话中,但如果不是,您就会明白......
然后在您的拦截器(或几乎任何地方)中,您可以通过以下方式获取线程的当前 orgId:
OrgId.orgId.get(); // Might be null.....
这里的一个潜在问题是所有这些组件(过滤器、OrgId 和拦截器)都需要由同一个类加载器加载,以确保 OrgId 类是有效的单例,否则,会有多个 ThreadLocal 实例挂在它周围将无法始终如一地工作,或者根本无法工作。不用说,所有这些都需要在同一个虚拟机中进行。
我不确定这是否是解决此问题的最简洁方法,但它确实可以将您的 orgId 带到您需要的地方。