Spring 会话 - WebFlux 与自定义 Cookie

本指南介绍如何在基于 WebFlux 的应用程序中配置 Spring 会话以使用自定义 Cookie。本指南假设您已使用所选数据存储在项目中设置了 Spring 会话。例如,使用 Redis 的 HttpSession

您可以在 WebFlux 自定义 Cookie 示例应用程序 中找到完成的指南。

设置 Spring 会话后,您可以通过将 WebSessionIdResolver 公开为 Spring Bean 来自定义会话 Cookie 的写入方式。Spring 会话默认使用 CookieWebSessionIdResolver。将 WebSessionIdResolver 公开为 Spring Bean 会在您使用 @EnableRedisHttpSession 等配置时增强现有配置。以下示例展示了如何自定义 Spring 会话的 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 我们将 Cookie 的 SameSite 指令自定义为 Strict

本部分介绍如何使用 webflux-custom-cookie 示例应用程序。

你可以通过获取 源代码并调用以下命令来运行示例

$ ./gradlew :spring-session-sample-boot-webflux-custom-cookie:bootRun
要使示例正常工作,你必须在本地主机上 安装 Redis 2.8+ 并使用默认端口 (6379) 运行它。或者,你可以更新 RedisConnectionFactory 以指向 Redis 服务器。另一个选择是使用 Docker 在本地主机上运行 Redis。有关详细说明,请参阅 Docker Redis 存储库

你现在应该能够在 localhost:8080/ 访问应用程序

现在你可以使用该应用程序。使用以下信息填写表单

  • 属性名称: username

  • 属性值: rob

现在单击 设置属性 按钮。你现在应该看到表中显示的值。

如果你查看应用程序的 cookie,你可以看到 cookie 已保存到 JSESSIONID 的自定义名称中。