深入解析Spring Boot中的注解@PathVariable、@RequestParam、@RequestBody的正确使用

news2024/11/18 2:59:31

文章目录

    • 1. 引言
    • 2. @PathVariable:处理路径变量
      • 2.1 简介
      • 2.2 使用示例
    • 3. @RequestParam:处理请求参数
      • 3.1 简介
      • 3.2 使用示例
    • 4. @RequestBody:处理请求体
      • 4.1 简介
      • 4.2 使用示例
    • 5. 多个注解的组合使用
    • 6. 参数绑定的原理
      • 6.1 HandlerMethodArgumentResolver的工作流程
      • 6.2 扩展HandlerMethodArgumentResolver
    • 7. 参数的验证与异常处理
    • 8. 性能优化与拓展
      • 8.1 参数绑定的性能优化
      • 8.2 拓展参数解析器
    • 9. 总结

在这里插入图片描述

🎉深入解析Spring Boot中的注解@PathVariable、@RequestParam、@RequestBody的正确使用


  • ☆* o(≧▽≦)o *☆嗨~我是IT·陈寒🍹
  • ✨博客主页:IT·陈寒的博客
  • 🎈该系列文章专栏:架构设计
  • 📜其他专栏:Java学习路线 Java面试技巧 Java实战项目 AIGC人工智能 数据结构学习
  • 🍹文章作者技术和水平有限,如果文中出现错误,希望大家能指正🙏
  • 📜 欢迎大家关注! ❤️

1. 引言

在Spring Boot中,通过使用注解来处理请求参数是极为常见的场景。@PathVariable@RequestParam@RequestBody是其中的三个核心注解,它们分别用于处理路径变量、请求参数和请求体。本文将深入解析这三个注解的正确使用方式,通过代码示例和详细解释,帮助读者更好地理解在不同场景下如何正确使用这些注解。
在这里插入图片描述

2. @PathVariable:处理路径变量

2.1 简介

@PathVariable注解用于从请求路径中获取变量的值。它常用于RESTful风格的请求,将路径中的一部分作为参数传递给方法。

2.2 使用示例

@RestController
@RequestMapping("/api/users")
public class UserController {

    @GetMapping("/{userId}")
    public ResponseEntity<User> getUserById(@PathVariable Long userId) {
        // 根据用户ID查询用户信息
        User user = userService.getUserById(userId);

        if (user != null) {
            return new ResponseEntity<>(user, HttpStatus.OK);
        } else {
            return new ResponseEntity<>(HttpStatus.NOT_FOUND);
        }
    }
}

在上述示例中,@GetMapping("/{userId}")表示处理/api/users/{userId}路径的GET请求,并通过@PathVariable注解将userId作为方法参数接收。

在这里插入图片描述

3. @RequestParam:处理请求参数

3.1 简介

@RequestParam注解用于从请求中获取查询参数。它适用于处理表单提交或URL中的查询参数。

3.2 使用示例

@RestController
@RequestMapping("/api/users")
public class UserController {

    @GetMapping("/search")
    public ResponseEntity<List<User>> searchUsers(
            @RequestParam String username,
            @RequestParam(required = false) Integer age
    ) {
        // 根据用户名和年龄查询用户列表
        List<User> users = userService.searchUsers(username, age);

        return new ResponseEntity<>(users, HttpStatus.OK);
    }
}

在上述示例中,@GetMapping("/search")表示处理/api/users/search路径的GET请求,并通过@RequestParam注解分别接收username和可选参数age

4. @RequestBody:处理请求体

4.1 简介

@RequestBody注解用于接收请求体中的数据,通常用于处理POST请求,将请求体的JSON或XML数据转化为Java对象。

4.2 使用示例

@RestController
@RequestMapping("/api/users")
public class UserController {

    @PostMapping
    public ResponseEntity<User> createUser(@RequestBody UserRequest userRequest) {
        // 从请求体中创建用户
        User user = userService.createUser(userRequest);

        return new ResponseEntity<>(user, HttpStatus.CREATED);
    }
}

在上述示例中,@PostMapping表示处理/api/users路径的POST请求,并通过@RequestBody注解将请求体中的JSON数据映射为UserRequest对象。

5. 多个注解的组合使用

在实际应用中,我们可能需要同时使用多个注解来处理不同类型的参数。以下是一个示例,演示了@PathVariable@RequestParam@RequestBody的组合使用:

@RestController
@RequestMapping("/api/users")
public class UserController {

    @GetMapping("/{userId}")
    public ResponseEntity<User> getUserById(@PathVariable Long userId) {
        // 根据用户ID查询用户信息
        User user = userService.getUserById(userId);

        if (user != null) {
            return new ResponseEntity<>(user, HttpStatus.OK);
        } else {
            return new ResponseEntity<>(HttpStatus.NOT_FOUND);
        }
    }

    @GetMapping("/search")
    public ResponseEntity<List<User>> searchUsers(
            @RequestParam String username,
            @RequestParam(required = false) Integer age
    ) {
        // 根据用户名和年龄查询用户列表
        List<User> users = userService.searchUsers(username, age);

        return new ResponseEntity<>(users, HttpStatus.OK);
    }

    @PostMapping
    public ResponseEntity<User> createUser(@RequestBody UserRequest userRequest) {
        // 从请求体中创建用户
        User user = userService.createUser(userRequest);

        return new ResponseEntity<>(user, HttpStatus.CREATED);
    }
}

在这个示例中,getUserById方法使用了@PathVariablesearchUsers方法使用了@RequestParam,而createUser方法使用了@RequestBody,通过这种方式,我们可以处理不同类型的请求参数。

在这里插入图片描述

6. 参数绑定的原理

了解注解的正确使用还需要了解参数绑定的原理。Spring Boot通过

HandlerMethodArgumentResolver来完成参数绑定,它负责将请求中的参数值映射到方法的参数上。

6.1 HandlerMethodArgumentResolver的工作流程

  1. 解析参数注解: Spring Boot首先会遍历方法的参数,识别出使用了哪些注解,如@PathVariable@RequestParam@RequestBody等。

  2. 查找对应的HandlerMethodArgumentResolver: 根据参数注解,Spring Boot会查找合适的HandlerMethodArgumentResolver,每个注解对应一个HandlerMethodArgumentResolver

  3. 参数解析: 通过找到的HandlerMethodArgumentResolver,Spring Boot会将请求中的参数值解析成方法参数的实际值。

6.2 扩展HandlerMethodArgumentResolver

在某些情况下,我们可能需要自定义参数的解析逻辑。这时,可以通过实现HandlerMethodArgumentResolver接口来扩展Spring Boot的参数解析器。

以下是一个简单的示例,展示了如何扩展一个自定义的参数解析器:

public class CustomArgumentResolver implements HandlerMethodArgumentResolver {

    @Override
    public boolean supportsParameter(MethodParameter parameter) {
        return parameter.getParameterType().equals(CustomType.class);
    }

    @Override
    public Object resolveArgument(
            MethodParameter parameter,
            ModelAndViewContainer mavContainer,
            NativeWebRequest webRequest,
            WebDataBinderFactory binderFactory
    ) throws Exception {
        // 自定义解析逻辑
        // ...
        return customValue;
    }
}

在上述示例中,supportsParameter方法用于判断是否支持解析特定类型的参数,而resolveArgument方法则实现了具体的参数解析逻辑。

7. 参数的验证与异常处理

在处理参数的同时,参数的验证也是一个重要的方面。Spring Boot提供了强大的参数验证功能,通过@Valid注解和BindingResult对象,我们能够对参数进行验证,并处理验证失败的情况。

以下是一个简单的参数验证示例:

@RestController
@RequestMapping("/api/users")
public class UserController {

    @PostMapping
    public ResponseEntity<User> createUser(@Valid @RequestBody UserRequest userRequest, BindingResult result) {
        // 参数验证
        if (result.hasErrors()) {
            // 处理验证失败的情况
            return new ResponseEntity<>(HttpStatus.BAD_REQUEST);
        }

        // 从请求体中创建用户
        User user = userService.createUser(userRequest);

        return new ResponseEntity<>(user, HttpStatus.CREATED);
    }
}

在上述示例中,通过@Valid注解标记了UserRequest参数,同时使用BindingResult对象来处理验证失败的情况。

8. 性能优化与拓展

8.1 参数绑定的性能优化

在实际应用中,当请求参数较多或者复杂时,参数绑定的性能可能成为一个关注点。可以通过以下方式进行性能优化:

  • 使用基本类型: 在可能的情况下,使用基本类型而非包装类型,减少自动装箱的开销。

  • 避免复杂对象: 尽量避免使用过于复杂的对象作为方法参数,减少反射和复杂对象创建的开销。

8.2 拓展参数解析器

除了扩展参数解析器外,还可以通过自定义注解和HandlerMethodArgumentResolver来实现更灵活的参数处理逻辑。例如,定义一个自定义注解@CurrentUser,并通过HandlerMethodArgumentResolver将当前用户绑定到方法参数上。

9. 总结

本文深入解析了Spring Boot中的注解@PathVariable@RequestParam@RequestBody的正确使用方式。通过代码示例和详细解释,读者能够更好地理解在不同场景下如何使用这些注解。同时,了解了参数绑定的原理和性能优化的相关内容,以及如何扩展和拓展Spring Boot中的参数处理逻辑。在实际应用中,根据具体需求选择合适的注解和处理方式,能够提高代码的可读性和可维护性,更好地发挥Spring Boot的优势。


🧸结尾 ❤️ 感谢您的支持和鼓励! 😊🙏
📜您可能感兴趣的内容:

  • 【Java面试技巧】Java面试八股文 - 掌握面试必备知识(目录篇)
  • 【Java学习路线】2023年完整版Java学习路线图
  • 【AIGC人工智能】Chat GPT是什么,初学者怎么使用Chat GPT,需要注意些什么
  • 【Java实战项目】SpringBoot+SSM实战:打造高效便捷的企业级Java外卖订购系统
  • 【数据结构学习】从零起步:学习数据结构的完整路径

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1298792.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用条件格式突出显示单元格数据-sdk

使用条件格式突出显示单元格数据 2023 年 12 月 6 日 根据数据值将视觉提示应用于特定单元格、行或列&#xff0c;从而更轻松地识别模式和趋势。 网格中的条件格式允许用户根据单元格或范围包含的数据将视觉样式应用于单元格或范围。它通过以数据驱动的方式突出显示关键值、异常…

nodejs微信小程序+python+PHP在线学习平台设计与实现-计算机毕业设计推荐

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

结构体相关知识

结构体的概念 结构体说直白点就是自定义类型&#xff0c;c语言有很多内置的类型比如char&#xff0c;int&#xff0c;double等&#xff0c;而结构体就是我们自己命名的一种类型。 区别在于内置类型大多都是单一描述的类型&#xff0c;比如 char studentnamewangwu,只能描述一…

使用 HTML 地标角色提高可访问性

请务必确保所有用户都可以访问您的网站&#xff0c;包括使用屏幕阅读器等辅助技术的用户。 一种方法是使用 ARIA 地标角色来帮助屏幕阅读器用户轻松浏览您的网站。使用地标角色还有其他好处&#xff0c;例如改进 HTML 的语义并更轻松地设置网站样式。在这篇博文中&#xff0c;我…

小米手机锁屏时间设置为永不休眠_手机不息屏_保持亮屏

环境&#xff1a;打开手机自带的锁屏时间设置发现没有 永不息屏的选项 原因&#xff1a;采用了三星OLED屏幕&#xff0c;所以根据OLED屏幕特性&#xff0c;这个是为了防止烧屏而特意设计的。非OLED机型支持设置“永不” 解决方案1&#xff1a;原生系统是支持永不锁屏的&#…

Java程序编写(上)

HelloWorld 1 创建一个以java为后缀名的文件 编写代码 public class Hello {public static void main(String[] args) {System.out.println("Hello, World!");} }其中&#xff0c;psvm是下述代码的缩写&#xff1a; public static void main(String[] args) sout是…

无人机语音中继电台 U-ATC118

简介 甚高频无线电中继通讯系统使用经过适航认证的机载电台连接数字网络传输模块&#xff0c;通过网络远程控制无缝实现无人机操作员与塔台直接语音通话。无人机操作员可以从地面控制站远程操作机载电台进行频率切换、静噪开关、PTT按钮&#xff0c;电台虚拟面板与真实面板布局…

C语言定长数组 变长数组 柔性数组

C语言定长数组 变长数组 柔性数组 文章目录 C语言定长数组 变长数组 柔性数组1. 定长数组2. 变长数组3. 柔性数组3.1 结构体的大小3.2 柔性数组的使用 1. 定长数组 在C99标准之前&#xff0c;C语言在创建数组的时候&#xff0c;数组的大小只能使用常量&#xff0c;常量表达式来…

CPU的三大调度

计算机系统中的调度可以分为不同层次&#xff0c;包括作业调度、内存调度和进程调度。这三种调度分别负责管理和优化计算机系统中不同层次的资源分配和执行顺序。 高级调度&#xff1a;作业调度&#xff08;Job Scheduling&#xff09;&#xff1a; 作业调度是指对提交到计算…

国产Type-C PD芯片—接口快充取电芯片

常用USB PDTYPE-C受电端&#xff0c;即设备端协议IC芯片&#xff08;PD Sink&#xff0c;也叫PD诱骗芯片&#xff09;&#xff0c;诱导取电芯片。 产品介绍 LDR6328: ◇ 采用 SOP-8 封装 ◇ 兼容 USB PD 3.0 规范&#xff0c;支持 USB PD 2.0 ◇ 兼容 QC 3.0 规范&#x…

Python绘制多分类ROC曲线

目录 1 数据集介绍 1.1 数据集简介 1.2 数据预处理 2随机森林分类 2.1 数据加载 2.2 参数寻优 2.3 模型训练与评估 3 绘制十分类ROC曲线 第一步&#xff0c;计算每个分类的预测结果概率 第二步&#xff0c;画图数据准备 第三步&#xff0c;绘制十分类ROC曲线 1 数据集…

TailwindCSS 如何设置 placeholder 的样式

前言 placeholder 在前端多用于 input、textarea 等任何输入或者文本区域的标签&#xff0c;它用户在用户输入内容之前显示一些提示。浏览器自带的 placeholder 样式可能不符合设计规范&#xff0c;此时就需要通过 css 进行样式美化。 当项目中使用 TailwindCSS 处理样式时&a…

手把手教你使用axure9画出图书出借的功能界面(原型模型)从0实现图书借阅界面

问题 设计图书出借的功能界面&#xff0c;并使用axure画出界面原型&#xff08;pc端或移动端都可以&#xff09;。就你的设计&#xff0c;你觉得有哪些方面需要跟用户沟通确认&#xff1f; 一、登录界面 1.先将图片背景改成灰色 2.插入文本框 3.插入文字&#xff0c;输入图书…

物联网第十四周总结

本周任务 消息转换器 PostgreSQL学习&#xff0c;JetLinks配置PostgreSQL 问题与总结 JetLinks配置PostgreSQL的时候&#xff0c;启动报错 2023-12-08 09:34:30.478 ERROR 19028 --- [actor-tcp-nio-1] o.h.e.r.e.r.r.R2dbcReactiveSqlExecutor : > Error: c…

Elasticsearch 8.9 refresh刷Es缓冲区的数据到Lucene,更新segemnt,使数据可见

一、相关API的handler1、接受HTTP请求的hander(RestRefreshAction)2、往数据节点发送刷新请求的action(TransportRefreshAction)3、数据节点接收主节点refresh传输的action(TransportShardRefreshAction) 二、在IndexShard执行refresh操作1、根据入参决定是使用lucene提供的阻塞…

Http请求(bug)——路径变量传参遇到特殊符号的问题 URL中的#,?,符号作用

前言 本篇博客分析路径变量传参遇到特殊符号的问题&#xff0c;阐述了URL中的#&#xff0c;&#xff1f;&#xff0c;&符号作用。 目录 前言引出路径变量传参遇到特殊符号的问题问题描述问题分析 URL中的 #&#xff0c;&#xff1f;&#xff0c;&符号的作用URL中# 的作…

【探索Linux】—— 强大的命令行工具 P.21(多线程 | 线程同步 | 条件变量 | 线程安全)

阅读导航 引言一、线程同步1. 竞态条件的概念2. 线程同步的概念 二、条件变量1. 条件变量函数⭕使用前提&#xff08;1&#xff09;初始化条件变量&#xff08;2&#xff09;等待条件满足&#xff08;3&#xff09;唤醒等待pthread_cond_broadcast()pthread_cond_signal() &…

Qexo博客后台管理部署

Qexo博客后台管理部署 个人主页 个人博客 参考文档 https://www.oplog.cn/qexo/本地部署 采用本地Docker部署管理本地Hexo 下载代码包 若无法下载使用科学工具下载到本地在上传到服务器 wget https://github.com/Qexo/Qexo/archive/refs/tags/3.0.1.zip# 解压 unzip Qexo…

SQL命令---修改字段的排列位置

介绍 使用sql语句表字段的排列顺序。 命令 alter table 表名 modify 字段名1 数据类型 first|after 字段名2;例子 将a表中的age字段改为表的第一个字段。 alter table a modify age int(12) first;下面是执行命令后的表结构&#xff1a; 将a表中的age字段放到name字段之…

【linux】查看CPU和内存信息

之前咱们一起学习了查看内存的和CPU的命令。 ​mpstat &#xff1a; 【linux】 mpstat 使用 uptime&#xff1a;【Linux】 uptime命令使用 CPU的使用率&#xff1a;【linux】查看CPU的使用率 nmon &#xff1a;【linux】nmon 工具使用 htop &#xff1a;【linux】htop 命令…