Runnable中HttpServletRequest丢失的问题。

public class Test extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(final HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        ScheduledExecutorService ses = Executors.newSingleThreadScheduledExecutor();
        T t = new T(req);
        ses.scheduleAtFixedRate(t, 0, 5000, TimeUnit.MILLISECONDS);
    }
}
public class T implements Runnable {
    public HttpServletRequest req;

    public T(HttpServletRequest req){
        this.req = req;
        System.out.println(req.getSession()+"---------------");
    }

    public void run() { 
            System.out.println(req.getSession()+"---------------");
            try {
                Connection conn = JdbcUtil.open();
                conn.setAutoCommit(false);
            } catch (SQLException e) {
                e.printStackTrace();
            }
            System.out.println(req.getSession()+"==============");
    }
}

这种情况应该是request请求结束了获取不到了,你可以已在new T(req) 之前 拷贝一个request ,把这个request的所有值复制到你拷贝的,传给线程的时候用拷贝的request