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

RESTFUL接口文档设计指南

这里写目录标题

  • API简要描述
  • 协议
  • 域名
  • 版本化你的API
  • 路径
  • 请求类型
    • 常用类型
      • GET
        • 单条数据查询
        • 请求列表
      • POST
        • 单条数据插入
        • 批量数据插入
      • PUT
      • DELETE
        • 单条数据删除
        • 批量删除
    • 不常用
      • PATCH
  • 状态码
  • 错误处理
  • 请求参数规范
  • 返回结构与参数说明
  • RESTFUL接口文档示例
          • 简要描述
          • 请求URL
          • 请求方式
          • 参数类型
          • 参数
          • 返回示例
          • 返回参数说明
          • 备注

API简要描述

注明作者信息,API功能

协议

通信协议使用https

域名

API应该部署在专用域名

例如:https://api.demo.com

版本化你的API

版本号放在API的url中

例如:https://api.demo.com/v1

路径

表示API的具体网址,restful风格中通常网址标识资源,只能有名词,且与数据库表名一致,常用复数形式。当使用API提供医院的信息,还包括部门,医生的信息时,API路径设计如下:

  1. https://api.demo.com/v1/hospitals
  2. https://api.demo.com/v1/departments
  3. https://api.demo.com/v1/doctors

请求类型

使用http动词表示请求类型
对同一资源所做的 增/删/改/查 操作的API,路径通常一样,只有发起请求的类型不同
前端写请求拦截器时通常把参数名为params的处理为query类型,把参数名为data的处理为body类型
如下:

常用类型

GET

常用于向服务器请求获取数据,可获取单条或列表

单条数据查询

请求参数通常拼接在URL后,即参数类型为query,如下:

https://api.demo.com/v1/doctors?id=2

请求列表

- API中通常需要加上list
- 常使用分页查询模式(传参pageIndex,pageSize)
- 可加入额外参数进行条件查询
- 参数类型为query

分页查询医生列表的API 可设计如下:

https://api.demo.com/v1/doctors/list?pageIndex=1&pageSize=10

POST

常用于向服务器请求新建资源,即对数据库进行插入操作的API

单条数据插入

请求参数通常放在请求体body里,参数类型为body,新增一个医生数据的API路径如下:

https://api.demo.com/v1/doctors

批量数据插入

  • 路径通常需要加入batch
  • 参数通常为数组
  • 参数类型通常为body
    批量增加医生数据的API路径如下:

https://api.demo.com/v1/doctors/batch

PUT

常用于向服务器请求修改资源,即对数据库进行修改操作的API
请求参数通常放在body里,例如修改一个医生信息的API路径如下:

https://api.demo.com/v1/doctors

DELETE

常用于向服务器请求删除资源,即对数据库进行删除数据操作的API

单条数据删除

参数通常拼接在url里,参数类型为query,删除一个医生信息的API路径如下:

https://api.demo.com/v1/doctors

批量删除

  • 参数通常放在body里
  • 参数通常为数组
  • 路径通常要加batch
    批量删除医生的API路径如下:

https://api.demo.com/v1/doctors/batch

不常用

PATCH

状态码

常用状态码如下:

  • 200 OK - [GET]:服务器成功返回用户请求的数据,该操作是幂等的(Idempotent)。
  • 201 CREATED - [POST/PUT/PATCH]:用户新建或修改数据成功。
  • 202 Accepted - [*]:表示一个请求已经进入后台排队(异步任务)
  • 204 NO CONTENT - [DELETE]:用户删除数据成功。
  • 400 INVALID REQUEST - [POST/PUT/PATCH]:用户发出的请求有错误,服务器没有进行新建或修改数据的操作,该操作是幂等的。
  • 401 Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误)。
  • 403 Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的。
  • 404 NOT FOUND - [*]:用户发出的请求针对的是不存在的记录,服务器没有进行操作,该操作是幂等的。
  • 406 Not Acceptable - [GET]:用户请求的格式不可得(比如用户请求JSON格式,但是只有XML格式)。
  • 410 Gone -[GET]:用户请求的资源被永久删除,且不会再得到的。
  • 422 Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误。
  • 500 INTERNAL SERVER ERROR - [*]:服务器发生错误,用户将无法判断发出的请求是否成功。
    用于修改部分信息,参数为只需要修改的字段内容,而put需要提供该数据所有字段信息

错误处理

后台进行错误拦截后输入错误提示信息用于前台展示给用户

请求参数规范

将请求参数按参数名,类型,参数说明的表格形式展示,如下:

参数名称类型参数说明是否必须
pageIndexnumber页码,默认为1false
pageSizenumber页大小,默认为10false

返回结构与参数说明

返回结构通常固定为以下内容:

{
	code: 200,
	message: 'success',
	data: {} / []
}
参数名类型说明
idbigintid
namestring名称
isRequiredint是否必填,1代表是,0代表否,默认1
typestring类型

RESTFUL接口文档示例

简要描述
  • 作者:XXX
  • 分页查询用户信息接口
请求URL
  • /demo/user/list
请求方式
  • GET
参数类型
  • QUERY
参数
参数名称类型参数说明是否必须
pageIndexnumber页码,默认为1false
pageSizenumber页大小,默认为10false
返回示例
  {
    "code": 200,
    "message": "success",
    "data": [
		{
			"id": "用户id",
			"name": "用户名",
			"nickName": "昵称",
			"role": "角色",
			"status": "状态",
		},
		{
			"id": "用户id",
			"name": "用户名",
			"nickName": "昵称",
			"role": "角色",
			"status": "状态",
		},
		...
	]
  }
返回参数说明
参数名类型说明
idint用户id
namevarchar用户名
nickNamevarchar昵称
rolevarchar角色
statusvarchar状态
备注
  • 根据筛选条件查询用户信息,若没有参数则返回全部用户信息

相关文章:

  • JS用forEach遍历数组时无法用return退出
  • Element——el-table给所有的row和column数据加上索引
  • 使用ElementUI开发的情况下,多使用Layout布局
  • Element——el-table单元格无法设置外边距,只能通过border-width实现间隔效果
  • 分支开发模式Git常用操作
  • /deep/和 >>>以及 ::v-deep 三者的区别
  • Vue——子组件中引入父组件
  • Vue——$attrs和$listeners
  • JS代码优化技巧——持续更新
  • 文字居于div底部的方式
  • Element——el-table设置单元格间距
  • Vue——插槽语法
  • Element——给el-table表头添加*
  • Element——tooltip无效和自定义内容
  • Vue——provide/inject的使用
  • Angular 响应式表单 基础例子
  • echarts的各种常用效果展示
  • iOS小技巧之UIImagePickerController实现头像选择
  • javascript面向对象之创建对象
  • js数组之filter
  • JS正则表达式精简教程(JavaScript RegExp 对象)
  • 给Prometheus造假数据的方法
  • 和 || 运算
  • 设计模式(12)迭代器模式(讲解+应用)
  • 王永庆:技术创新改变教育未来
  • 用jQuery怎么做到前后端分离
  • LIGO、Virgo第三轮探测告捷,同时探测到一对黑洞合并产生的引力波事件 ...
  • Nginx惊现漏洞 百万网站面临“拖库”风险
  • $forceUpdate()函数
  • (Redis使用系列) Springboot 使用redis的List数据结构实现简单的排队功能场景 九
  • (ZT)北大教授朱青生给学生的一封信:大学,更是一个科学的保证
  • (ZT)一个美国文科博士的YardLife
  • (定时器/计数器)中断系统(详解与使用)
  • (翻译)Entity Framework技巧系列之七 - Tip 26 – 28
  • (附源码)springboot车辆管理系统 毕业设计 031034
  • (附源码)ssm跨平台教学系统 毕业设计 280843
  • (附源码)计算机毕业设计SSM在线影视购票系统
  • (黑马C++)L06 重载与继承
  • (七)Knockout 创建自定义绑定
  • .NET 3.0 Framework已经被添加到WindowUpdate
  • .NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
  • .NET Core 控制台程序读 appsettings.json 、注依赖、配日志、设 IOptions
  • .NET 的静态构造函数是否线程安全?答案是肯定的!
  • .net 获取url的方法
  • .Net 知识杂记
  • .net 桌面开发 运行一阵子就自动关闭_聊城旋转门家用价格大约是多少,全自动旋转门,期待合作...
  • .net6+aspose.words导出word并转pdf
  • .net实现头像缩放截取功能 -----转载自accp教程网
  • @Bean注解详解
  • @DataRedisTest测试redis从未如此丝滑
  • []FET-430SIM508 研究日志 11.3.31
  • []常用AT命令解释()
  • []使用 Tortoise SVN 创建 Externals 外部引用目录
  • [bug总结]: Feign调用GET请求找不到请求体实体类
  • [fsevents@^2.1.2] optional install error: Package require os(darwin) not compatible with your platfo