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

Restful API 设计示例

Restful API 设计示例

一 ,HTTP状态码

✔️正例:

200: 返回成功

说明:200表示成功,4xx表示客户端异常,5xx表示服务端异常,参见HTTP 的返回码含义

❌反例:

除了200就是500

说明:如果不细化状态码,前端很难充分的显示错误信息,比如警告信息和错误信息显示样式不一样

二 , 返回数据格式

✔️正例:

{"data": {}, "message": "Success!", "status": 0, "requestId": 1609139633881
}

说明:data 主要负责存放数据,message 主要存放应用的请求日志, status 负责存储应用状态, requestId 负责存储本次请求的唯一识别码,方便排查错误

❌反例:

{"data": {"userid": 123}}

说明:只有数据,出了异常前端很难识别

三, 请求方法

✔️正例:

GET: 获取数据

POST: 创建数据

PUT: 更新数据

DELETE: 删除数据

说明:很容易和资源的操作的增删改查对应起来,一个路由多次使用,减少路由的数量

❌反例:

获取数据,使用GET

所有的接口都是POST

说明:获取数据必须是幂等(不改变结果), 可以直接在浏览器调试,更方便

四, 请求URL格式

✔️正例:

/event/type/element

说明:很容易看出来是递进关系,需要操作的是事件类型要素,尽量不要使用复数

❌反例:

/event_type_element

说明:没有递进关系

❌反例:

/data/import

说明:最好不要出现动词,否则破坏超文本协议(HTTP)对资源的抽象的概念,这种情况可以写成/importor/extract_data 表示导入抽取数据

http://www.lryc.cn/news/195203.html

相关文章:

  • 为知笔记一个日记模板
  • 软件测试中如何测试算法?
  • CMOS图像传感器——Sony Ta-Kuchi图像传感器
  • 一文理解登录鉴权(Cookie、Session、Jwt、CAS、SSO)
  • LangChain结合milvus向量数据库以及GPT3.5结合做知识库问答之一 --->milvus的docker compose安装
  • 安装nginx,配置https,并解决403问题
  • RustDay04------Exercise[11-20]
  • 【Python第三方包】快速获取硬件信息和使用情况(psutil、platform)
  • 数据结构与算法课后题-第五章(哈夫曼树和哈夫曼编码)
  • 07测试Maven中依赖的范围,依赖的传递原则,依赖排除的配置
  • 科技为饮食带来创新,看AI如何打造智能营养时代
  • 软件测试知识库+1,5款顶级自动化测试工具推荐和使用分析
  • 代码随想录算法训练营第23期day22|669. 修剪二叉搜索树、108.将有序数组转换为二叉搜索树、538.把二叉搜索树转换为累加树
  • IDEA中创建Web工程流程
  • 【论文阅读】基于卷积神经的端到端无监督变形图像配准
  • 【Rust】包和模块,文档注释,Rust格式化输出
  • leetcode221.最大正方形
  • 低代码技术这么香,如何把它的开发特点发挥到极致?
  • drawio简介以及下载安装
  • Sql Server 数据库中的所有已定义的唯一约束 (列名称 合并过了)
  • elasticsearch (六)filebeat 安装学习
  • 算法通关村第一关|青铜|链表笔记
  • 【记录】使用Python读取Tiff图像的几种方法
  • JOSEF约瑟 多档切换式漏电(剩余)继电器JHOK-ZBL1 30/100/300/500mA
  • Linux部署kubeedge 1.4
  • 第一章习题
  • nvm、node、npm解决问题过程记录
  • Linux- DWARF调试文件格式
  • 软件工程第六周
  • node+pm2安装部署