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

Spring Boot中的RESTful API详细介绍及使用

在Spring Boot中,RESTful API的实现通过控制器类中的方法和特定的注解来完成。每个注解对应不同的HTTP请求方法,并通过处理请求参数和返回响应来实现不同的操作。

下面将详细解释RESTful API中的各个方面,包括@GetMapping, @PostMapping, @PutMapping, 和 @DeleteMapping的作用及区别、请求参数和返回参数。

作用及区别

  1. @GetMapping:

    • 作用: 处理HTTP GET请求,用于获取资源。通常用于读取数据,不应更改服务器上的资源。
    • 区别: 是幂等的,多次请求相同资源不会改变服务器状态。
    • 示例:
      @GetMapping("/users")
      public List<User> getAllUsers() {// 获取所有用户
      }@GetMapping("/users/{id}")
      public User getUserById(@PathVariable Long id) {// 获取指定ID的用户
      }
      
  2. @PostMapping:

    • 作用: 处理HTTP POST请求,用于创建新资源。通常用于提交数据,服务器会创建新的资源。
    • 区别: 不是幂等的,多次请求会创建多个资源。
    • 示例:
      @PostMapping("/users")
      public User createUser(@RequestBody User user) {// 创建新用户
      }
      
  3. @PutMapping:

    • 作用: 处理HTTP PUT请求,用于更新资源。通常用于更新现有资源的全部内容。
    • 区别: 是幂等的,多次请求相同资源会导致相同的更新结果。
    • 示例:
      @PutMapping("/users/{id}")
      public User updateUser(@PathVariable Long id, @RequestBody User user) {// 更新指定ID的用户
      }
      
  4. @DeleteMapping:

    • 作用: 处理HTTP DELETE请求,用于删除资源。通常用于删除服务器上的资源。
    • 区别: 是幂等的,多次请求相同资源删除操作只会导致资源被删除一次。
    • 示例:
      @DeleteMapping("/users/{id}")
      public void deleteUser(@PathVariable Long id) {// 删除指定ID的用户
      }
      

请求参数

  1. @RequestBody:

    • 作用: 将请求体中的JSON数据绑定到方法参数上。
    • 使用场景: 常用于@PostMapping@PutMapping
    • 示例:
      @PostMapping("/users")
      public User createUser(@RequestBody User user) {// 请求体中的JSON数据将绑定到user对象
      }
      
  2. @PathVariable:

    • 作用: 将URL路径中的变量绑定到方法参数上。
    • 使用场景: 常用于@GetMapping, @PutMapping, 和 @DeleteMapping
    • 示例:
      @GetMapping("/users/{id}")
      public User getUserById(@PathVariable Long id) {// URL中的id将绑定到方法参数id
      }
      
  3. @RequestParam:

    • 作用: 将查询参数绑定到方法参数上。
    • 使用场景: 适用于各种HTTP方法。
    • 示例:
      @GetMapping("/users")
      public List<User> getUsersByAge(@RequestParam int age) {// URL中的查询参数age将绑定到方法参数age
      }
      

返回参数

  1. 返回对象:

    • 作用: 方法可以直接返回对象,Spring Boot会自动将其转换为JSON格式。
    • 示例:
      @GetMapping("/users/{id}")
      public User getUserById(@PathVariable Long id) {// 返回User对象,自动转换为JSON
      }
      
  2. ResponseEntity:

    • 作用: 可以自定义HTTP响应状态码、响应头和响应体。
    • 示例:
      @PostMapping("/users")
      public ResponseEntity<User> createUser(@RequestBody User user) {User createdUser = userService.createUser(user);return ResponseEntity.status(HttpStatus.CREATED).body(createdUser);
      }
      

综合示例

@RestController
@RequestMapping("/api/users")
public class UserController {@GetMappingpublic List<User> getAllUsers() {// 获取所有用户return userService.findAll();}@GetMapping("/{id}")public ResponseEntity<User> getUserById(@PathVariable Long id) {User user = userService.findById(id);if (user == null) {return ResponseEntity.notFound().build();}return ResponseEntity.ok(user);}@PostMappingpublic ResponseEntity<User> createUser(@RequestBody User user) {User createdUser = userService.createUser(user);return ResponseEntity.status(HttpStatus.CREATED).body(createdUser);}@PutMapping("/{id}")public ResponseEntity<User> updateUser(@PathVariable Long id, @RequestBody User user) {User updatedUser = userService.updateUser(id, user);if (updatedUser == null) {return ResponseEntity.notFound().build();}return ResponseEntity.ok(updatedUser);}@DeleteMapping("/{id}")public ResponseEntity<Void> deleteUser(@PathVariable Long id) {userService.deleteUser(id);return ResponseEntity.noContent().build();}
}

总结

Spring Boot中的RESTful API通过使用@GetMapping, @PostMapping, @PutMapping, 和 @DeleteMapping注解,使得每种HTTP请求类型都能简便地映射到控制器的方法上。

通过@RequestBody, @PathVariable, 和 @RequestParam处理请求参数,并利用返回对象或ResponseEntity构建响应,使得RESTful API的开发变得高效且易维护。

http://www.lryc.cn/news/373901.html

相关文章:

  • nlp学习笔记
  • 使用python获取内存信息
  • 外包公司泛滥,这些常识你应该提前知道?
  • Linux下的抓包工具使用介绍
  • centos环境上:k8s 简单安装教程
  • 短视频矩阵系统/源码搭建---拆解热门视频功能开发上线
  • 手机和模拟器的 Frida 环境配置
  • 力扣1385.两个数组间的距离值
  • [C++] 小游戏 斗破苍穹 2.11.6 版本 zty出品
  • 认识与学习JSP
  • MySql 各种 join
  • 【Android面试八股文】Android中操作多线程的方式有哪些?
  • 语义分割和目标检测的关系
  • SpringBoot 大文件基于md5实现分片上传、断点续传、秒传
  • 数据资产治理与数据质量提升:构建完善的数据治理体系,确保数据资产的高质量与准确性
  • SylixOS下UDP组播测试程序
  • Web前端快速开发平台:革命性工具,提升开发效率的新篇章
  • 内窥镜系统设计简介
  • 使用Spring Boot实现Redis多数据库缓存
  • 揭秘newSingleThreadExecutor:深度解析与源码探秘
  • 使用python绘制三维散点图
  • Vue51-插件
  • python将一个整数转为字符串列表
  • PTA 6 - 20 汉诺塔问题(py 递归)
  • 深度学习Day-20:DenseNet算法实战 乳腺癌识别
  • 给类设置serialVersionUID
  • Android之实现两段颜色样式不同的文字拼接进行富文本方式的显示
  • GenICam标准(五)
  • 《人生海海》读后感
  • SpringBoot自定义Starter及原理分析