news 2026/4/2 6:32:14

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【后端】【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 风格,不仅是学会几个注解,更重要的是理解资源导向和统一接口设计思想


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 6:11:25

52、Samba与分布式文件系统(DFS)全解析

Samba与分布式文件系统(DFS)全解析 1. Samba连接与文件操作 Samba是一种强大的工具,可让Linux服务器与Windows网络集成。我们可以尝试连接之前创建的共享(samba - share),以clientB主机为例,使用smbclient工具连接到serverA上的共享。 - 连接共享 :使用 smbclien…

作者头像 李华
网站建设 2026/3/20 13:29:50

Cesium快速入门19:Entity折线材质

上一节课我们把“面”的材质讲完了&#xff0c;今天换“线”——折线&#xff08;Polyline&#xff09;。 不管是道路、航线还是飞线特效&#xff0c;全靠下面几种现成材质&#xff0c;一句代码就能换皮肤。一、最朴素的红线先画两个点&#xff0c;宽度 5 像素&#xff0c;纯红…

作者头像 李华
网站建设 2026/3/30 13:40:32

C51_HC-05蓝牙通信

文章目录一、蓝牙   1、蓝牙的特点   2、蓝牙特性二、HC-05   1、简介   2、主要参数   3、引脚   4、模块原理图   5、工作模式     1&#xff09;、命令响应工作模式     2&#xff09;、自动连接工作模式     3&#xff09;、进入命令响应工作模式…

作者头像 李华
网站建设 2026/3/25 15:03:52

前端工程师必看:AI+前端+A/B测试 实战指南(小白友好版)

前端工程师必看&#xff1a;AI前端A/B测试 实战指南&#xff08;小白友好版&#xff09; 是不是总觉得“AI”“A/B测试”这些技术离自己很远&#xff1f;其实现在前端已经能直接对接AI能力、落地A/B测试了&#xff01;这篇文章会从**“是什么→前端要做什么→怎么实现”** 一步…

作者头像 李华
网站建设 2026/3/31 0:31:47

2、初探Puppet清单编写

初探Puppet清单编写 1. Puppet简介与重要性 在过去几年里,配置管理在IT领域变得越来越重要。特别是对于服务器操作而言,如果没有强大的管理基础设施,几乎无法进行。在众多可用的配置管理工具中,Puppet已成为最受欢迎和广泛使用的解决方案之一。它最初由Luke Kanies编写,…

作者头像 李华