常见用于从 HTTP 请求中提取数据的注解

在 Spring 框架中,处理 HTTP 请求并从中提取数据的注解有很多,具体取决于请求的类型(如 GET、POST、PUT 等)以及数据的来源(如请求头、路径、查询参数、请求体等)。以下是一些常见的注解,用于从 HTTP 请求中提取不同的数据。

1. @RequestParam

用于从 URL 查询参数 或 表单数据 中提取参数。常用于 GET 请求或表单提交的 POST 请求。

用法:用于从查询字符串(例如 ?name=John&age=30)或表单数据中提取参数。

示例:

java 复制代码
@GetMapping("/search")
public String search(@RequestParam String name, @RequestParam int age) {
    return "Searching for " + name + " aged " + age;
}

通过 URL 查询字符串传递数据:

sql 复制代码
GET /search?name=John&age=30

常见选项:

required: 设置为 false 时,参数可以是可选的。

defaultValue: 设置默认值,当请求中没有该参数时使用。

2. @PathVariable

用于从 URL 路径 中提取数据。适用于 RESTful 风格的 API,通常用于动态路径参数。

用法:从 URL 路径中提取变量部分。

示例:

java 复制代码
@GetMapping("/user/{id}")
public String getUser(@PathVariable String id) {
    return "User ID: " + id;
}

通过 URL 路径传递数据:

java 复制代码
GET /user/123

常见选项:

可以使用多个 @PathVariable 注解提取多个路径参数。

3. @RequestBody

用于从 HTTP 请求的请求体 中提取数据,通常用于处理 JSON 或 XML 格式的数据。

用法:提取请求体中的内容并将其转换为 Java 对象(通常是 JSON)。

示例:

java 复制代码
@PostMapping("/user")
public String createUser(@RequestBody User user) {
    return "Created user: " + user.getName();
}

请求体的示例(JSON 格式):

json 复制代码
{
  "name": "John",
  "age": 30
}

常见选项:

需要配置 HttpMessageConverter(如 Jackson)来自动转换请求体的 JSON 数据为 Java 对象。

4. @RequestHeader

用于从 HTTP 请求头 中提取数据。常用于获取请求中的元数据,如认证信息、内容类型、语言设置等。

用法:用于提取请求头中的信息。

示例:

java 复制代码
@GetMapping("/header")
public String getHeader(@RequestHeader("User-Agent") String userAgent) {
    return "User-Agent: " + userAgent;
}

请求头的示例:

json 复制代码
User-Agent: Mozilla/5.0

常见选项:

required: 设置为 false 时,表示请求头参数是可选的。

5. @CookieValue

用于从 HTTP 请求的 Cookie 中提取数据。通常用于获取存储在客户端浏览器中的 Cookie 值。

用法:用于提取 Cookie 中的数据。

示例:

java 复制代码
@GetMapping("/cookie")
public String getCookie(@CookieValue("session_id") String sessionId) {
    return "Session ID: " + sessionId;
}

请求头的示例:

json 复制代码
Cookie: session_id=abcd1234

常见选项:

defaultValue: 如果 Cookie 中没有值,可以设置默认值。

6. @ModelAttribute

用于将 表单数据(或请求参数)绑定到一个 Java 对象。通常用于处理表单提交的 POST 请求。

用法:将多个请求参数绑定到一个 Java 对象中,通常用于表单数据提交。

示例:

java 复制代码
@PostMapping("/user")
public String createUser(@ModelAttribute User user) {
    return "Created user: " + user.getName();
}

表单提交的示例:

html 复制代码
<form method="post" action="/user">
    <input type="text" name="name">
    <input type="number" name="age">
    <button type="submit">Submit</button>
</form>
7. @RequestMapping

这是一个通用的注解,通常与 method 属性一起使用,来映射请求路径和 HTTP 方法。它可以与其他注解(如 @RequestParam、@PathVariable 等)结合使用来提取请求参数。

用法:@RequestMapping 可以处理各种 HTTP 方法,如 GET、POST、PUT、DELETE 等。

示例:

java 复制代码
@RequestMapping(value = "/product/{id}", method = RequestMethod.GET)
public String getProduct(@PathVariable String id, @RequestParam String name) {
    return "Product ID: " + id + ", Product Name: " + name;
}
8. @RequestParam 和 @PathVariable 的结合使用

你可以同时使用 @RequestParam 和 @PathVariable 来提取不同来源的数据。

示例:

java 复制代码
@GetMapping("/product/{id}")
public String getProduct(@PathVariable String id, @RequestParam String name) {
    return "Product ID: " + id + ", Product Name: " + name;
}

请求 URL:

bash 复制代码
GET /product/123?name=ProductA

总结

@RequestParam:用于从查询参数或表单数据中提取数据。

@PathVariable:用于从 URL 路径中提取数据。

@RequestBody:用于从请求体中提取数据(如 JSON 或 XML 格式)。

@RequestHeader:用于从请求头中提取数据。

@CookieValue:用于从请求的 Cookie 中提取数据。

@ModelAttribute:用于将多个请求参数绑定到一个 Java 对象。

@RequestMapping:用于映射 HTTP 请求到控制器方法,可以结合其他注解使用。

这些注解可以灵活地与 Spring 的控制器方法结合使用,帮助你从 HTTP 请求的不同部分提取所需的数据。

相关推荐
邂逅星河浪漫1 天前
【RabbitMQ】消息队列·详解+实操演示+功能实现(微服务架构)
rabbitmq·springboot·springamqp·consumer·exchange·producer·queue
vortex52 天前
用 Scoop 快速部署 JeecgBoot 开发环境:从依赖安装到服务管理
java·windows·springboot·web·开发·jeecg-boot
javpy6 天前
为什么Service层和Mapper层需要实现interface接口
java·springboot
古渡蓝按6 天前
基于 Word 模板占位符的动态文档生成实践(源码+保姆版)
springboot
带刺的坐椅6 天前
Solon (可替换 SpringBoot)集成 Docker 实战:30分钟搞定轻量级应用容器化部署
java·docker·jar·springboot·solon
程序员杨工7 天前
【原创】SpringBoot3+Vue3客户管理系统
vue.js·springboot
bug攻城狮8 天前
SaaS多租户架构实践:字段隔离方案(共享数据库+共享Schema)
mysql·架构·mybatis·springboot·1024程序员节
后端小张12 天前
【JAVA 进阶】SpringBoot集成Sa-Token权限校验框架深度解析
java·spring boot·spring·架构·sa-token·springboot·权限框架
梁辰兴12 天前
企业培训笔记:外卖平台后端--套餐管理模块--新建套餐信息
笔记·vue·mybatis·springboot·外卖管理系统
No8g攻城狮13 天前
【异常解决】使用DateUtil.isSameDay()方法判断秒级时间戳是否属于同一天踩过的坑
java·jvm·spring boot·java-ee·springboot