Spring Session - 基于自定义 Cookie 的 WebFlux

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

您可以在WebFlux 自定义 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 存储库

您现在应该能够通过localhost:8080/访问该应用程序。

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

  • 属性名称: username

  • 属性值: rob

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

如果您查看应用程序的 Cookie,您可以看到 Cookie 已保存到自定义名称 `JSESSIONID`。