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

【后端】【Java】一文深入理解 Spring Boot RESTful 风格接口开发

深入理解 Spring Boot RESTful 风格接口开发

一、什么是 RESTful?

RESTful 是一种基于REST(Representational State Transfer,表述性状态转移)架构风格的 Web 接口设计规范。

在 RESTful 风格中:

  • 一切皆资源

  • 通过 URL 表示资源

  • 通过 HTTP 方法描述对资源的操作

  • 使用统一的数据格式进行交互(通常是 JSON)

Spring Boot 天生适合用于构建 RESTful 风格接口,因此在现代 Java Web 开发中被广泛采用。


二、RESTful 的核心设计思想

1️⃣ 资源导向(Resource-Oriented)

RESTful 强调“资源”而不是“动作”。

❌ 不推荐:

/getUserById?id=1 /deleteUser?id=1

✅ 推荐:

/users/1

资源通常使用名词复数表示:

  • /users

  • /orders

  • /products


2️⃣ 使用 HTTP 方法表示行为

HTTP 方法含义示例
GET查询资源GET /users/1
POST创建资源POST /users
PUT更新资源(整体)PUT /users/1
PATCH更新资源(部分)PATCH /users/1
DELETE删除资源DELETE /users/1

URL 不变,行为由 HTTP 方法决定,这是 RESTful 的核心思想之一。


3️⃣ 无状态(Stateless)

RESTful 接口要求:

  • 服务端不保存客户端状态

  • 每次请求都包含完整信息(参数、Token 等)

这使得系统:

  • 更易扩展

  • 更适合分布式和微服务架构


4️⃣ 统一数据格式

目前最常见的数据交互格式是JSON,相比 XML:

  • 更轻量

  • 可读性更好

  • 前后端支持更友好


三、Spring Boot 对 RESTful 的天然支持

Spring Boot 基于 Spring MVC,提供了大量用于 REST 开发的注解,极大降低了开发成本。


四、Spring Boot RESTful 常用注解详解

1️⃣@RestController

@RestController public class UserController { }

等价于:

@Controller @ResponseBody

👉 表示该类中所有方法返回的都是JSON 数据,而不是视图页面。


2️⃣ 请求映射相关注解

@RequestMapping

通用映射注解:

@RequestMapping(value = "/users", method = RequestMethod.GET)
推荐使用语义更清晰的派生注解:
@GetMapping @PostMapping @PutMapping @DeleteMapping @PatchMapping

示例:

@GetMapping("/users") public List<User> listUsers() { return userService.findAll(); }

3️⃣@PathVariable(路径参数)

@GetMapping("/users/{id}") public User getUser(@PathVariable Long id) { return userService.findById(id); }

URL 示例:

GET /users/1

👉RESTful 强烈推荐使用路径参数来定位资源


4️⃣@RequestParam(查询参数)

@GetMapping("/users") public List<User> queryUsers(@RequestParam String name) { return userService.findByName(name); }

URL 示例:

GET /users?name=Tom

5️⃣@RequestBody(请求体)

用于接收 JSON 数据:

@PostMapping("/users") public User createUser(@RequestBody User user) { return userService.save(user); }

前端请求体示例:

{ "name": "Tom", "age": 20 }

五、RESTful 接口完整示例

1️⃣ 实体类

public class User { private Long id; private String name; private Integer age; // getter & setter }

2️⃣ Controller 示例

@RestController @RequestMapping("/users") public class UserController { @GetMapping("/{id}") public User getUser(@PathVariable Long id) { return new User(id, "Tom", 20); } @PostMapping public User createUser(@RequestBody User user) { return user; } @PutMapping("/{id}") public User updateUser(@PathVariable Long id, @RequestBody User user) { user.setId(id); return user; } @DeleteMapping("/{id}") public void deleteUser(@PathVariable Long id) { // 删除逻辑 } }

六、JSON 序列化与反序列化原理

Spring Boot 默认使用Jackson进行 JSON 处理。

✔ 序列化

Java 对象 → JSON

✔ 反序列化

JSON → Java 对象

开发者通常无需手动处理,Spring Boot 会通过HttpMessageConverter自动完成。


七、常用 Jackson 注解

1️⃣@JsonIgnore

@JsonIgnore private String password;

👉 返回 JSON 时忽略该字段


2️⃣@JsonProperty

@JsonProperty("user_name") private String name;

👉 自定义 JSON 字段名


3️⃣@JsonFormat

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") private LocalDateTime createTime;

👉 常用于时间字段格式化


八、RESTful 接口设计最佳实践

✅ URL 使用名词复数
✅ 不在 URL 中出现动词
✅ 正确使用 HTTP 状态码
✅ 统一返回结构
✅ 接口版本控制(如/api/v1/users

示例返回结构:

{ "code": 200, "message": "success", "data": {} }

九、总结

Spring Boot 提供了极其完善的 RESTful 开发支持,使得:

  • 接口定义简洁清晰

  • JSON 处理高度自动化

  • 易于前后端分离

  • 适合微服务架构

掌握 RESTful 风格,不仅是学会几个注解,更重要的是理解资源导向和统一接口设计思想


http://www.jsqmd.com/news/84865/

相关文章:

  • 创客匠人峰会新解:AI 时代知识变现的 “信任分层” 法则 —— 从流量到高客单的进阶密码
  • 52、Samba与分布式文件系统(DFS)全解析
  • 真相!Dify和n8n这两款LLM应用开发平台的最大区别,90%的人都不知道!
  • Linux编辑器—vim的使用
  • 创客匠人峰会实战拆解:三重杠杆撬动千万知识变现 —— 联盟 + IP+AI 的效率革命
  • 创客匠人峰会深度洞察:人文底蕴 + 商业闭环,AI 时代知识变现的 “内外兼修” 之道
  • 【后端】【Java】一文详解Spring Boot 统一日志与链路追踪实践
  • 【后端】【Java】《Spring Boot 统一接口耗时统计实践:基于 HandlerInterceptor 的工程级方案》
  • 【大前端】【Android】一文详解Android MVVM 模式详情解析
  • 46、Asterisk VoIP系统配置指南
  • 【后端】【Java】RESTful书面应该如何写
  • 45、对等网络文件共享与网关互通性解析
  • 【微科普】Louvain 算法,附python代码,让复杂网络 “自己抱团”!
  • 运输层核心总结
  • HarmonyOS 关系型数据库 RDB 数据持久化(ArkTS)实战:建库建表、CRUD、事务、FTS、性能优化,一篇搞懂
  • Cesium快速入门20:Primitive的外观设置Appearance
  • Cesium快速入门19:Entity折线材质
  • 【Codeforces】【Div2】CF 2176
  • Lonsdor K518 PRO FCV Expert License Activation for BMW, MINI, Rolls-Royce Key Programming
  • 应用层复习总结
  • 构建下一代AI算力基石 CANN ops-transformer算子仓库的生态价值与设计哲学
  • STM32F103C8T6 + SI24R1实现2.4G通信
  • 昇腾Ascend C Add算子开发实战-从理论到代码的完整构建
  • AFE为何物
  • 实验实验实验实验。
  • 代码随想录算法训练营第三十三天:零钱兑换,完全平方数,单词拆分
  • 令人“悲哀”的 C# 游戏生态 —— 主流引擎支持现状与现实困境
  • 单车慢跑中的节奏建议
  • 工具分享:彻底解决Docker拉取慢/超时,解放双手!自动测速优选配置镜像源 代理切换脚本
  • CS配合CrossC2插件,实现MacOS/Linux上线