发布时间:2025-12-09 13:43:30 浏览次数:4
在进行前后端联调的时候,由于想实现一个登出操作,前端自动删除浏览器存储的cookie,想通过document.cookie来获取进而进行删除操作,但是发现浏览器有cookie;但是无法获取到情况遂记录
documen.cookie发现获取不到,浏览器控制台也同样//后端代码public static void addCookie(HttpServletResponse response, String name, String value, String domain, int maxAge) { try { Cookie cookie = new Cookie(name, URLEncoder.encode(value, "utf-8")); cookie.setPath("/"); cookie.setDomain(domain); cookie.setMaxAge(maxAge); cookie.setHttpOnly(true); //后端设置httpOnly属性为true response.addCookie(cookie); } catch (Exception var6) { throw new RuntimeException(var6.getMessage()); }}documen.cookie就能够获取到HttpOnly是2016年微软为IE6而新增了这一属性
HttpOnly是包含在http返回头Set-Cookie里面的一个附加的flag,所以它是后端服务器对cookie设置的一个附加的属性,在生成cookie时使用HttpOnly标志有助于减轻客户端脚本访问受保护cookie的风险(如果浏览器支持则会显示,若不支持则选择传统方式)