对于最新的稳定版本,请使用 Spring Session 3.5.2! |
常见配置
本节包含适用于所有或大多数 Spring Session 模块的常见配置。它包含以下用例的配置示例:
自定义会话 Cookie
设置 Spring Session 后,您可以通过公开CookieSerializer
作为 Spring bean。Spring Session 附带DefaultCookieSerializer
. 公开DefaultCookieSerializer
作为 Spring bean 在您使用@EnableRedisHttpSession
. 以下示例显示了如何自定义 Spring Session 的 cookie:
@Bean
public CookieSerializer cookieSerializer() {
DefaultCookieSerializer serializer = new DefaultCookieSerializer();
serializer.setCookieName("JSESSIONID"); (1)
serializer.setCookiePath("/"); (2)
serializer.setDomainNamePattern("^.+?\\.(\\w+\\.[a-z]+)$"); (3)
return serializer;
}
1 | 我们将 cookie 的名称自定义为JSESSIONID . |
2 | 我们将 cookie 的路径自定义为 (而不是上下文根的默认值)。/ |
3 | 我们将域名模式(正则表达式)自定义为^.?\\.(\\w\\.[a-z]+)$ . 这允许跨域和应用程序共享会话。如果正则表达式不匹配,则不设置域并使用现有域。如果正则表达式匹配,则使用第一个分组作为域。这意味着对 child.example.com 的请求将域设置为example.com . 但是,对 localhost:8080/ 或 192.168.1.100:8080/ 的请求会使 cookie 保持未设置状态,因此,在开发中仍然可以工作,而无需对生产进行任何更改。 |
应仅匹配有效的域字符,因为域名会反映在响应中。这样做可以防止恶意用户执行 HTTP 响应拆分等攻击。 |
配置选项
以下配置选项可用:
-
cookieName
:要使用的 Cookie 的名称。 违约:SESSION
. -
useSecureCookie
:指定是否应使用安全 Cookie。默认值:使用HttpServletRequest.isSecure()
在创作时。 -
cookiePath
:Cookie 的路径。默认值:上下文根。 -
cookieMaxAge
:指定创建会话时要设置的 Cookie 的最大期限。 违约:-1
,这表示在浏览器关闭时应删除 cookie。 -
jvmRoute
:指定要附加到会话 ID 并包含在 cookie 中的后缀。用于标识要路由到哪个 JVM 以实现会话关联。对于某些实现(即 Redis),此选项不会提供性能优势。但是,它可以帮助跟踪特定用户的日志。 -
domainName
:允许指定要用于 cookie 的特定域名。此选项易于理解,但通常需要在开发环境和生产环境之间进行不同的配置。 看domainNamePattern
作为替代方案。 -
domainNamePattern
:一种不区分大小写的模式,用于从HttpServletRequest#getServerName()
. 该模式应提供用于提取 cookie 域值的单个分组。如果正则表达式不匹配,则不设置域并使用现有域。如果正则表达式匹配,则使用第一个分组作为域。 -
sameSite
:的值SameSite
cookie 指令。要禁用序列化SameSite
cookie 指令,您可以将此值设置为null
. 违约:Lax
-
rememberMeRequestAttribute
:指示记住我登录的请求属性名称。如果指定,则 cookie 将写入为Integer.MAX_VALUE
.
如果您正在使用 |
WebFlux 中的自定义 Cookie
您可以通过公开WebSessionIdResolver
作为春豆。
Spring Session 使用CookieWebSessionIdResolver
默认情况下。
以下示例显示了如何自定义 Spring Session 的 cookie:
@Bean
public WebSessionIdResolver webSessionIdResolver() {
CookieWebSessionIdResolver resolver = new CookieWebSessionIdResolver();
resolver.setCookieName("JSESSIONID"); (1)
resolver.addCookieInitializer((builder) -> builder.path("/")); (2)
resolver.addCookieInitializer((builder) -> builder.sameSite("Strict")); (3)
return resolver;
}
1 | 我们将 cookie 的名称自定义为JSESSIONID . |
2 | 我们将 cookie 的路径自定义为 (而不是上下文根的默认值)。/ |
3 | 我们定制SameSite cookie 指令设置为Strict . |