Spring框架下的RESTful风格重构

前言

REST,即“表现层状态转移”,它确立了互联网软件服务的架构规则。若一个架构契合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代码如下:

@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();
    }
}

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/12638.html

(0)
LomuLomu
上一篇 2025 年 6 月 25 日
下一篇 2025 年 6 月 25 日

相关推荐

  • 2024年最新MacBook苹果电脑安装JDK8、JDK11、JDK17、JDK22教程,配置环境变量 + 快速切换JDK版本

    本帖发布日期:2024年01月26日,全网最新教程整理。 2024年02月01日更新:环境变量新增jdk17配置代码。 2024年05月13日更新:记录解决添加maven后不能自动切换jdk版本。 2024年06月16日更新:友情提醒:如果是m芯片,推荐下载arm版本。 2024年08月08日更新:新增JDK22版本安装。 2024年11月28日更新:更新排…

    2024 年 12 月 31 日
    73500
  • CLion激活后还可以更新吗?不会失效的秘诀!

    声明:本教程所涉及的 Clion 破解补丁与激活码均源自网络公开渠道,仅供个人学习研究之用,严禁商业用途。若条件允许,请支持正版! 废话不多说,先放一张成功激活到 2099 年的截图镇楼,看着就舒坦! 下面用图文结合的方式,手把手带你完成 Clion 2025.2.1 的激活全过程。 前期准备 ⚠️ 如果你之前尝试过其他补丁但失败,建议先卸载旧版本并重新安装…

    2025 年 9 月 19 日
    2900
  • PyCharm激活新手必看|破解步骤超简单!

    本教程适用于IDEA、PyCharm、DataGrip、Goland等,支持Jetbrains全家桶! 废话少说,先上成果图:最新版 PyCharm 已顺利“续命”到 2099 年,爽! 下面用图文手把手演示,如何把 PyCharm 一口气激活到 2099 年。老版本同样适用,Win / Mac / Linux 通杀,成功率 100%。 嫌折腾?直接买官方正…

    PyCharm激活码 2025 年 9 月 22 日
    3100
  • 🚀 2025年最新IDEA激活码 & 永久破解教程(支持JetBrains全家桶)

    💻 教程适用性 本教程完美适用于IntelliJ IDEA、PyCharm、DataGrip、GoLand等JetBrains全家桶产品!无论你使用哪个版本,都能轻松破解至2099年! 先给大家看看最新版IDEA成功破解的截图,有效期直达2099年,简直不要太爽!🎉 📥 下载IDEA安装包 还没下载IDEA的小伙伴,先去官网下载最新版:https://www…

    2025 年 6 月 15 日
    19900
  • 一文搞懂架构设计的衡量标准:功能性、可用性、性能、可扩展性、安全性、协作效率、复杂度、成本效益

    大家好,我是汤师爷~ 架构设计的首要目标是服务于业务需求。因此,我们不应该盲目追求所谓的”最厉害的”架构,而应该致力于寻找最适合当前业务环境和未来发展需求的架构方案。 衡量架构的合理性是一个复杂的过程,需要从多个角度进行全面评估。主要可以从以下视角进行分析: 功能需求视角:评估架构是否有效支撑当前业务需求,并具有充分的灵活性以适应未来业务发展。 非功能需求视…

    未分类 2025 年 1 月 15 日
    43700

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信