前言
最近在开发中,有一个业务需求需要把一段信息保存到服务器(不能保存到数据库),然后和同事讨论了一下,最终决定保存到cookie,当用户请求A方法时,A方法代码里面通过 response.addCookie()设置cookie保存到前端,但在B方法获取Cookie时,却不能获取的到,来看一下代码:
@GetMapping("demo1/cookie_one")
public String A(HttpServletRequest request, HttpServletResponse response){
//用户请求A方法,保存Cookie
Cookie cookie = new Cookie("username", "张三");
response.addCookie(cookie);
return "cookie_one";
}
用户发送请求: http://localhost:8090/demo1/cookie_one 时,这里会创建cookie对象,并通过response设置保存到浏览器,然后在B方法中获取时:
@GetMapping("demo2/cookie_two")
public String B(HttpServletRequest request, HttpServletResponse response){
//获取cookie
Cookie[] cookies = request.getCookies();
if (cookies != null && cookies.length > 0){
for (Cookie cookie : cookies) {
//获取cookie信息
System.out.println(cookie.getName() + "----" + cookie.getValue());
}
}
return "cookie_two";
}
用户请求B方法: http://localhost:8090/demo2/cookie_one,但是却得不到cookie中的数据,然后通过调式,发现 request.getCookies()一直为null,这就奇怪了,明明在A方法保存了Cookie,而且也没有涉及跨域等其它问题,为什么cookie会获取不到呢
解决
后来经过查阅发现,问题出现了在cookie在保存时默认路径的问题,A方法请求路径为:/demo1/cookie_one,B方法请求路径是: /demo2/cookie_two
仔细观察就会发现 A和B一个是demo1,一个是demo2,因为在A方法中没有指定cookie保存路径,所以它默认保存路径为上级父类的路径上, 比如A方法请求路径是: http://localhost:8090/demo1/cookie_one,那么它的上级父类路径就为: http://localhost:8090/demo1,这个也就是cookie默认的保存路径
当用户访问B方法时,根据cookie原则,只有请求为所在域 或 子域,cookie才会携带,例如:cookie保存在:http://localhost:8090/demo1 ,那么只有当发送的请求为:http://localhost:8090/demo1 或者 http://localhost:8090/demo1/** 下的路径时,该域下的cookie才会默认在请求头中携带,而B方法请求的路径却是:http://localhost:8090/demo2/cookie_one,所以这也就导致了cookie为什么会一直获取不到
故这里需要通过 cookie.setPtah("/")设置cookie的保存路径,这样才能在请求B方法时携带cookie
@GetMapping("demo1/cookie_one")
public String A(HttpServletRequest request, HttpServletResponse response){
//用户请求A方法,保存Cookie
Cookie cookie = new Cookie("username", "张三");
//设置cookie的保存路径
cookie.setPath("/");
response.addCookie(cookie);
return "cookie_one";
}