【Spring】RESTful设计风格

前言

REST(Representational State Transfer),即"表现层状态转移",它定义了互联网软件服务的架构原则。如果一个架构的符合 REST 原则,就被称之为 RESTful 架构,这是目前最流行的互联网软件服务架构设计风格之一。

REST 并不是一种标准,而更像是一种架构理念和设计原则,目的是为了让 Web API更加简洁、易于理解和使用

在开发过程中,后端时常需要向客户端提供API接口进行使用,在设计API接口时我们就需要尽可能让客户端能够快速理解API含义。如果在设计时遵守一定的规范,就能大大减少前后端沟通成本,提高开发效率了。

一、RESTful的特点

RESTful主要有以下几个特点:

1、同一资源使用同一个URI

2、规范统一接口☆

3、同一资源有多样表现形式(json/html)

4、客户端与服务端的请求交互是无状态的

5、可缓存(允许客户端缓存响应的内容)

无状态

http请求本身是无状态的,它是基于 client-server 架构的。每个请求从客户端到服务器必须包含所有必要的信息,以便服务器能够理解请求并独立地处理它。这意味着服务器不应该存储任何会话信息,无法从一次请求中获取之前请求的任何信息。

规范统一接口

让我们先来举个简单的例子。

比如传统开发要实现一个删除功能,其路径可能是下面这样:

GET http://localhost:8080/delete?id=20

而采用RESTful设计风格的路径则是这样的:

http://localhost:8080/users/20

怎么样看着是不是清爽很多。传统方式针对同一资源进行增删查改就可能需要四个不同的接口,维护起来并不方便。而RESTful主要特点就是通过资源进行分组,同一组别的系统组件之间的交互通过统一的接口进行。

比如针对用户的操作都由 users 这一URI(统一资源标识符)进行标识,获取、创建、更新、删除都通过统一的路径进行访问。那么服务端又该如何对不同操作进行区分呢?

通过规定使用标准的HTTP方法来执行操作,常见的方法有:

  • GET:获取资源。
  • POST:创建新资源。
  • PUT:更新现有资源。
  • DELETE:删除资源。
  • PATCH:对资源进行部分修改。

也就是说,使用RESTful规范后,针对统一资源操作的API就只剩一个了。要执行增删查改的操作,只需要使用不同的请求类型(HTTP Method)就行了。并且服务端返回的数据也可以是完全一致的,前端可以通过不同的HTTP状态码来判断请求是否成功。

二、Spring中实现RESTful API

Spring Boot 提供了对RESTful API的支持。主要通过与REST操作方式对应的注解来实现:

  • @GetMapping:处理GET请求,获取资源
  • @PostMapping:处理POST请求,新增资源
  • @PutMapping:处理PUT请求,更新资源
  • @DeleteMapping:处理DELETE请求,删除资源
  • @PatchMapping:处理PATCH请求,用于更新部分资源

在RESTful规范中,每个网址对应一个资源,因此在对URI命名时尽量采用名词,并且一般都与数据库的表明相对应。

比如用户管理模块的API就可以这么设定:

对应的Spring Boot代码就是:

java 复制代码
@RestController
@RequestMapping("/user")
public class UserController {
    //根据id获取用户信息
    @GetMapping("/{id}")
    public Result get(@RequestParam Integer id){
        //业务逻辑
        return Result.success();
    }
    //添加用户
    @PostMapping
    public Result add(@RequestBody User user){
        //业务逻辑
        return Result.success();
    }
    //修改用户信息
    @PutMapping
    public Result update(@RequestBody User user){
        //业务逻辑
        return Result.success();
    }
    //修改用户的某个参数,如密码、头像等
    @PatchMapping("/password")
    public Result updateAvatar(@RequestParam String password){
        //业务逻辑
        return Result.success();
    }
    //根据id删除用户
    @DeleteMapping("/{id}")
    public Result delete(@RequestParam Integer id){
        //业务逻辑
        return Result.success();
    }
}

那么本篇文章就到此为止了,如果觉得这篇文章对你有帮助的话,可以点一下关注和点赞来支持作者哦。如果有什么讲的不对的地方欢迎在评论区指出,希望能够和你们一起进步✊

相关推荐
無限進步D2 小时前
Java 运行原理
java·开发语言·入门
難釋懷2 小时前
安装Canal
java
是苏浙2 小时前
JDK17新增特性
java·开发语言
不光头强2 小时前
spring cloud知识总结
后端·spring·spring cloud
GetcharZp5 小时前
告别 Python 依赖!用 LangChainGo 打造高性能大模型应用,Go 程序员必看!
后端
阿里加多5 小时前
第 4 章:Go 线程模型——GMP 深度解析
java·开发语言·后端·golang
likerhood5 小时前
java中`==`和`.equals()`区别
java·开发语言·python
小小李程序员5 小时前
Langchain4j工具调用获取不到ThreadLocal
java·后端·ai