当前位置: 首页 > web >正文

Spring MVC @CookieValue 注解怎么用?

@CookieValue 注解的作用

@CookieValue 注解用于将 HTTP 请求中特定 Cookie 的值绑定到 Controller 方法的参数上。

Cookies 是由服务器发送到用户浏览器并保存在本地的一小块数据。浏览器在后续向同一服务器发送请求时,会通过 Cookie 请求头将这些数据再带回给服务器。Cookies 常用于:

  • 会话管理(如存储会话 ID)
  • 用户偏好设置(如主题、语言)
  • 跟踪用户行为

@CookieValue 提供了一种方便的方式来直接在 Controller 方法中访问这些 Cookie 的值,而无需手动解析 HttpServletRequest 中的 Cookie 头或 getCookies() 数组。

基本用法

需要指定要读取的 Cookie 的名称,并将带有 @CookieValue 注解的参数声明为相应类型(通常是 String)。

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.CookieValue;
import org.springframework.web.bind.annotation.ResponseBody;@Controller
public class CookieDemoController {// 读取名为 "sessionId" 的 Cookie 的值@GetMapping("/show-session-id")@ResponseBodypublic String showSessionId(@CookieValue("sessionId") String sessionId) {// 此时,如果请求中包含名为 "sessionId" 的 Cookie,// 其值会被自动赋给方法参数 sessionIdreturn "Session ID from cookie is: " + sessionId;}// 读取名为 "user-preference" 的 Cookie 的值@GetMapping("/show-preference")@ResponseBodypublic String showUserPreference(@CookieValue("user-preference") String preference) {return "User preference from cookie: " + preference;}
}

重要:

  • @RequestHeader 类似,name (或 value) 属性是必需的,用来指定要读取的 Cookie 的名称。因为方法参数名通常与 Cookie 名称不直接对应。

@CookieValue 的属性

@CookieValue 提供了一些属性来控制绑定行为:

  1. name (或 value):

    • 必需属性。指定要绑定的 Cookie 的名称。
    • namevalue 是同义词。
    • 示例:@CookieValue(name = "visitorId") String visitorId
  2. required:

    • 指定该 Cookie 是否必须存在于请求中。
    • 类型:boolean
    • 默认值:true。如果 required=true,但请求中没有该名称的 Cookie,Spring MVC 会抛出 MissingRequestCookieException 异常,导致 HTTP 400 (Bad Request) 响应。
    • 如果 Cookie 是可选的,需要设置为 required = false
  3. defaultValue:

    • 当请求中没有提供该 Cookie 时,为其提供一个默认值。
    • 类型:String
    • 注意: 使用 defaultValue 隐含了 required = false 的行为。提供了 defaultValue 后,即使不显式设置 required = false,该 Cookie 也不再是必需的。如果 Cookie 不存在,就会使用默认值,不会抛出异常。

处理可选 Cookie 和默认值

场景 1:Cookie 可选,如果不存在则为 null

import java.util.Optional;
// ...@GetMapping("/optional-cookie-demo")
@ResponseBody
public String processOptionalCookie(@CookieValue(name = "trackingId", required = false) String trackingId,@CookieValue(name = "abTestGroup", required = false) Optional<String> group) {String trackingMessage = (trackingId != null) ? "Tracking ID: " + trackingId : "Tracking ID cookie is missing";String groupMessage;if (group.isPresent()) {groupMessage = "A/B Test Group: " + group.get();} else {groupMessage = "A/B Test Group cookie is missing";}return trackingMessage + "\n" + groupMessage;
}
  • 使用 required = false,如果 Cookie 不存在,对应的 String 参数会是 null
  • 使用 Optional<String> (Spring 4.1+) 是处理可选值的一种安全的方式。

场景 2:Cookie 可选,如果不存在则使用默认值

@GetMapping("/theme-setting")
@ResponseBody
public String getThemeSetting(// 如果请求中没有名为 "appTheme" 的 Cookie,theme 参数的值将是 "light"@CookieValue(name = "appTheme", defaultValue = "light") String theme) {return "Current application theme (from cookie or default): " + theme;
}// 实践: 显式声明 required=false 增加可读性
@GetMapping("/language-setting")
@ResponseBody
public String getLanguageSetting(@CookieValue(name = "userLang", required = false, defaultValue = "en") String language) {return "User language (from cookie or default): " + language;
}

绑定到 javax.servlet.http.Cookie 对象

如果需要的不仅仅是 Cookie 的值,还想访问 Cookie 的其他属性(如 Path, Domain, MaxAge, HttpOnly 等),我们可以直接将参数类型声明为 javax.servlet.http.Cookie

import javax.servlet.http.Cookie;
// ...@GetMapping("/get-full-cookie")
@ResponseBody
public String getFullCookieObject(// 同样需要设置 required = false 来处理 Cookie 不存在的情况@CookieValue(name = "fullCookieExample", required = false) Cookie fullCookie) {if (fullCookie != null) {String name = fullCookie.getName();String value = fullCookie.getValue();String path = fullCookie.getPath();int maxAge = fullCookie.getMaxAge();boolean httpOnly = fullCookie.isHttpOnly();return String.format("Cookie '%s': Value=%s, Path=%s, MaxAge=%d, HttpOnly=%b",name, value, path, maxAge, httpOnly);} else {return "Cookie 'fullCookieExample' not found.";}
}

当绑定到 Cookie 对象时,defaultValue 属性不适用。只能通过 required = false 来处理 Cookie 不存在的情况(此时 fullCookie 参数将为 null)。

总结

  • @CookieValue 用于将 HTTP 请求中指定名称的 Cookie 的值绑定到方法参数。
  • 必须 使用 namevalue 属性来指定 Cookie 名称。
  • 使用 required = false 使 Cookie 变为可选(不存在时参数为 nullOptional.empty())。
  • 使用 defaultValue = "value" 为可选 Cookie 提供默认值(Cookie 不存在时生效,隐含 required=false)。
  • 参数类型通常是 String,但也可以直接绑定到 javax.servlet.http.Cookie 对象以访问 Cookie 的所有属性(此时 defaultValue 不可用,需用 required=false 处理缺失情况)。
  • 它是处理特定 Cookie 的便捷方式,用于区别处理查询参数 (@RequestParam)、路径变量 (@PathVariable)、请求头 (@RequestHeader) 或请求体 (@RequestBody)。
http://www.xdnf.cn/news/3770.html

相关文章:

  • 【前端】【面试】在 Vue-React 的迁移重构工作中,从状态管理角度来看,Vuex 迁移到 Redux 最大的挑战是什么,你是怎么应对的?
  • idea结合CopilotChat进行样式调整实践
  • 爬虫的应用
  • 测试基础笔记第十九天
  • CSS 变量与原生动态主题实现
  • 变更需求代价-影响分析过程
  • Hotspot分析(1):单细胞转录组识别信息基因(和基因模块)
  • 力扣面试150题--相同的树
  • windows鼠标按键自定义任意设置
  • 【中间件】brpc_基础_remote_task_queue
  • Oracle OCP认证考试考点详解083系列07
  • Vibe Coding 新时代:AI 辅助编程完全指南
  • 论企业集成平台的理解与应用
  • Linux时钟与时间API
  • 【MLLM】Qwen2.5-Omni-7B/3B模型
  • 【Mytais系列】缓存机制:一级缓存、二级缓存
  • 游戏代码C
  • python中的函数
  • PMP-第六章 项目进度管理(三)
  • 基于springboot的金院银行厅预约系统的设计及实现(源码+lw+部署文档+讲解),源码可白嫖!
  • Vue中的过滤器知道多少?从是什么、怎么用、应用场景、原理分析、示例解释
  • 第39课 绘制原理图——绘制命令在哪里?
  • C++11(1)
  • 优化高搜索量还是低竞争关键词?SEO策略解析
  • DNAT与SNAT
  • 剖析扩散模型(Denoising Diffusion Probabilistic Models)
  • 【序列贪心】摆动序列 / 最长递增子序列 / 递增的三元子序列 / 最长连续递增序列
  • 黑客学习计划
  • PowerBI企业运营分析——多维度日期指标分析
  • stm32f4 声音传感器采集