RESTful 是什么

一、核心定义

REST :全称 Representational State Transfer ,表述性状态转移,是一种软件架构设计风格 / 规范 ,不是协议、不是标准。RESTful :指遵循 REST 设计规范开发的接口 / 服务,日常说的「RESTful 接口」就是符合这套规则的前后端 API。

主要用于:前后端分离、微服务、第三方接口调用(手机 App、小程序、前端网页调后端接口)。


二、核心设计思想

  1. 资源为核心 所有东西都抽象为资源(用户、订单、商品、文章),每个资源有唯一 URL。
  2. 无状态服务器不存储客户端会话信息,每次请求带完整参数 / 令牌(Token),服务易扩容、集群部署。
  3. 用 HTTP 原生方法表达操作意图 不只用 POST 混用所有操作,严格区分:
  • GET:查询、获取数据(安全、幂等)
  • POST:新增资源
  • PUT:全量更新 / 修改资源
  • PATCH:局部更新
  • DELETE:删除资源

三、RESTful 接口规范示例(对比传统接口)

❶ 传统接口(不规范)

plaintext

复制代码
获取用户:/getUser?userId=1
新增用户:/addUser
修改用户:/updateUser
删除用户:/delUser?userId=1

❷ RESTful 规范写法

plaintext

复制代码
# 用户资源
GET    /users/1      # 查询id=1的用户
POST   /users        # 新增用户
PUT    /users/1      # 修改id=1的用户
DELETE /users/1      # 删除id=1的用户
  • URL 用名词复数(users、orders、goods)
  • 动作交给 HTTP 方法,URL 只写资源

四、配套规范

  1. 返回格式统一:统一用 JSON
  2. 状态码语义化
    • 200 成功、201 创建成功
    • 400 参数错误、401 未登录、403 无权限、404 资源不存在
    • 500 服务异常
  3. 版本控制/api/v1/users 方便迭代兼容
  4. 过滤 / 分页 / 排序 通过 URL 参数:/users?page=1&size=10&sort=createTime

五、优缺点

优点

  • 结构清晰、语义直观,前后端协作简单
  • 适配前后端分离、微服务、跨端调用
  • 无状态,天然适合分布式、负载均衡

缺点

  • 部分场景语义别扭(复杂业务操作)
  • 严格 REST 开发略繁琐,很多公司会弱化 REST(只保留风格,不完全严格)

六、通俗一句话总结

RESTful 就是利用 HTTP 原生请求方式,以「资源」为中心,统一、规范、简洁地设计后端 API 接口的一套开发风格,是目前互联网项目、金融系统、微服务最主流的接口设计方式。

相关推荐
Java编程爱好者1 小时前
这 4 种 SQL 写法,数据量一大就是生产事故(SQL 性能篇)
后端
小旭95271 小时前
分布式事务 Seata 详解 + 链路追踪 SkyWalking 实战
java·分布式·后端·信息可视化·skywalking
曹牧1 小时前
Spring:@RequestMapping 注解匹配顺序
java·后端·spring
AI攻城狮1 小时前
DeepSeek 的 Vision 能力要来了吗?
人工智能·后端·openai
用户622475758462 小时前
面试官问我:"如何实现你项目中的这块代码."我说:"看好了."
后端
空中海2 小时前
Nacos 2: Spring Boot Demo 实战
java·spring boot·后端
阿丰资源2 小时前
基于Spring Boot的美容院管理系统(附源码+数据库+文档)
数据库·spring boot·后端
TE-茶叶蛋2 小时前
Spring自动配置分析
java·后端·spring
北风toto2 小时前
SpringBoot 获取配置文件值、获取环境变量的方式
java·spring boot·后端