Spring Session - WebFlux 使用自定义 Cookie

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

您可以在webflux-custom-cookie 示例应用中找到完整的指南。

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

本节介绍如何使用 webflux-custom-cookie 示例应用。

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

$ ./gradlew :spring-session-sample-boot-webflux-custom-cookie:bootRun
为了使示例正常工作,您必须在 localhost 上安装 Redis 2.8+ 并使用默认端口 (6379) 运行它。或者,您可以更新 RedisConnectionFactory 以指向 Redis 服务器。另一种选择是使用 Docker 在 localhost 上运行 Redis。请参阅 Docker Redis repository 以获取详细说明。

您现在应该可以通过 localhost:8080/ 访问该应用程序

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

  • 属性名称: username

  • 属性值: rob

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

如果您查看该应用的 Cookie,您可以看到 Cookie 已保存为自定义名称 JSESSIONID