对于最新的稳定版本,请使用 Spring Session 3.3.1! |
对于最新的稳定版本,请使用 Spring Session 3.3.1! |
本指南介绍如何配置 Spring Session 以在基于 WebFlux 的应用程序中使用自定义 cookie。 本指南假设您已经使用所选的数据存储在项目中设置了 Spring Session。例如,带有 Redis 的 HttpSession。
您可以在 WebFlux 自定义 Cookie 示例应用程序中找到完整的指南。 |
您可以在 WebFlux 自定义 Cookie 示例应用程序中找到完整的指南。 |
Spring Boot 配置
设置 Spring Session 后,您可以通过将 a 公开为 Spring Bean 来自定义会话 cookie 的编写方式。
Spring Session 默认使用 。
当您使用类似 的配置时,将 公开为 Spring bean 会扩充现有配置。
以下示例演示如何自定义 Spring Session 的 cookie:WebSessionIdResolver
CookieWebSessionIdResolver
WebSessionIdResolver
@EnableRedisHttpSession
@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 | 我们将 cookie 指令自定义为 。SameSite Strict |
1 | 我们将 cookie 的名称自定义为 。JSESSIONID |
2 | 我们将 cookie 的路径自定义为(而不是上下文根的默认路径)。/ |
3 | 我们将 cookie 指令自定义为 。SameSite Strict |
webflux-custom-cookie
示例应用程序
本节介绍如何使用示例应用程序。webflux-custom-cookie
运行示例应用程序webflux-custom-cookie
可以通过获取源代码并调用以下命令来运行示例:
$ ./gradlew :spring-session-sample-boot-webflux-custom-cookie:bootRun
若要使示例正常工作,必须在 localhost 上安装 Redis 2.8+ 并使用默认端口 (6379) 运行它。
或者,您可以将指向 Redis 服务器更新。
另一种选择是使用 Docker 在 localhost 上运行 Redis。有关详细说明,请参阅 Docker Redis 存储库。RedisConnectionFactory |
您现在应该能够在 localhost:8080/ 访问该应用程序
若要使示例正常工作,必须在 localhost 上安装 Redis 2.8+ 并使用默认端口 (6379) 运行它。
或者,您可以将指向 Redis 服务器更新。
另一种选择是使用 Docker 在 localhost 上运行 Redis。有关详细说明,请参阅 Docker Redis 存储库。RedisConnectionFactory |