今天在修改代码时遇到个问题,发到这里请大家帮忙...
系统中的一些操作要求生成日志要获取操作人的信息,因为好多一些操作都通过DWR 但又不愿去修改所调用的代码。
我的做法是这样:
1.
在web.xml 中加入Filter 过滤/dwr/* 的请求.
2.
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
...
ThreadLocal threadLocal=new ThreadLocal();
threadLocal.set(loginBean);
...
}
3.
ThreadLocal threadLocal= new ThreadLocal();
LoginBean loginBean=threadLocal.get();
...
Filter 已工作,但是这里的 loginBean为什么一直都为null ?
请大家支招!!!
用错了,第二次调用get的时候不能再new一次了. 通常用法是把这个ThreadLocal搞成一个static变量, 这样只要在初始化的时候new一次就行了, 然后调用它的set和get方法就可以了.
看样子,你还得仔细理解一下threadlocal是怎么工作的.
Threadlocal是线程内共享变量,考虑塞的时候,和取的时候,是否是同一个变量(get的时候new就不是同一个变量),同一个线程。