Cookie
除了key
和value
以外有几个属性。
httpOnly
是否允许js读取cookiesecure
是否仅仅在https的链接下,才提交cookiedomain
cookie提交的域path
cookie提交的pathmaxAge
cookie存活时间sameSite
同站策略,枚举值:Strict
Lax
None
其他的都很熟悉了,最后一个是 Chrome 51 开始,浏览器的 Cookie 新增加了一个 SameSite
属性,用来防止 CSRF 攻击和用户追踪。
关于
SameSite
的详细解释 可以看 Cookie 的 SameSite 属性
在Javaweb应用中 ,设置 Cookie一般都是用 javax.servlet.http.Cookie
,但是SameSite
属性出来不久,Servlet
库还没更新,所以没有设置SameSite
的方法.
javax.servlet.http.Cookie 中定义的的属性
可以看到,还没有SameSite
的定义
//
// The value of the cookie itself.
//
private String name; // NAME= ... "$Name" style is reserved
private String value; // value of NAME
//
// Attributes encoded in the header's cookie fields.
//
private String comment; // ;Comment=VALUE ... describes cookie's use
// ;Discard ... implied by maxAge < 0
private String domain; // ;Domain=VALUE ... domain that sees cookie
private int maxAge = -1; // ;Max-Age=VALUE ... cookies auto-expire
private String path; // ;Path=VALUE ... URLs that see the cookie
private boolean secure; // ;Secure ... e.g. use SSL
private int version = 0; // ;Version=1 ... means RFC 2109++ style
private boolean isHttpOnly = false;
通过 ResponseCookie 给客户端设置Cookie
本质上,Cookie
也只是一个header
。我们可以不使用Cookie
对象,而通过自定义Header
的方式来给客户端设置Cookie
。
ResponseCookie
是Spring定义的一个Cookie
构建工具类,极其简单
import java.time