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

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

设置 Spring Session 后,您可以通过将 a 公开为 Spring Bean 来自定义会话 cookie 的编写方式。 Spring Session 默认使用 。 当您使用类似 的配置时,将 公开为 Spring bean 会扩充现有配置。 以下示例演示如何自定义 Spring Session 的 cookie:WebSessionIdResolverCookieWebSessionIdResolverWebSessionIdResolver@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 指令自定义为 。SameSiteStrict
1 我们将 cookie 的名称自定义为 。JSESSIONID
2 我们将 cookie 的路径自定义为(而不是上下文根的默认路径)。/
3 我们将 cookie 指令自定义为 。SameSiteStrict

本节介绍如何使用示例应用程序。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/ 访问该应用程序

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

  • 属性名称:用户名

  • 属性值:rob

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

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

若要使示例正常工作,必须在 localhost 上安装 Redis 2.8+ 并使用默认端口 (6379) 运行它。 或者,您可以将指向 Redis 服务器更新。 另一种选择是使用 Docker 在 localhost 上运行 Redis。有关详细说明,请参阅 Docker Redis 存储库RedisConnectionFactory