海西先知 2018-12-27 10:13 采纳率: 0%
浏览 765

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()+"==============");
    }
}
  • 写回答

1条回答 默认 最新

  • 钢弹~ 2018-12-27 05:53
    关注

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

    评论

报告相同问题?