JavaWeb最开始时如何获取 cookie 中的 JSESSIONID
如果 cookie 里已经有了JSESSIONID ,那就可以从 request 中获取。
但是它是怎么来的呢?答:是在最开始生成会话的时候来的。那如果想要在生成的时候,就获取到JSESSIONID 该怎么做?
答:也是有方法的,在生成JSESSIONID 的时候,从 response 的 header 里获取。
这里就需要知道,具体是哪个方法生成了JSESSIONID.
多次测试发现,request.getSession() 的时候,就已经生成JSESSIONID。所以要想 获取到jsessionid,得先调用一下getSession()
private void setJsessionIdCookie(HttpServletRequest servletRequest, HttpServletResponse servletResponse) {
HttpSession httpSession = servletRequest.getSession();
// 只有首次登录的时候,这里才会有cookie,并且它的值是JSESSIONID
if (servletResponse.getHeader("Set-Cookie") != null) {
String value = servletResponse.getHeader("Set-Cookie");
if (value.startsWith("JSESSIONID=") && YhtUtil.getTgcCookieSecure()) {
value = value + "; Secure; SameSite=none";
servletResponse.setHeader("Set-Cookie", value);
}
}
}
原创文章,欢迎转载,转载请注明出处!
把每一件简单的事情做好,就是不简单;把每一件平凡的事情做好,就是不平凡!相信自己,创造奇迹~~