您当前的位置:首页 > 电脑百科 > 程序开发 > 编程百科

API 接口设计规范

时间:2019-09-09 11:12:03  来源:  作者:
API 接口设计规范

 

协议

http
https(使用HTTPS协议,以确保交互数据的传输安全)

域名

专门的api应用使用独立域名 https://api.example.com
简单的可使用api前缀区分 https://www.example.com/api

版本控制

接口版本的控制,可以在程序发布时,不同版本的业务逻辑在一定程度上避免受到影响。

https://api.example.com/v{n}
  • 应该将API的版本号放入URL。
  • 采用多版本并存,增量发布的方式。
  • n代表版本号,分为整型和浮点型
  • 整型: 大功能版本, 如v1、v2、v3 ...
  • 浮点型: 补充功能版本, 如v1.1、v1.2、v2.1、v2.2 ...

URL规则

  • 在RESTful架构中,每个网址代表一种资源(resource),所以网址中不能有动词,只能有名词。 【所用的名词往往与数据库的表格名对应】
  • 数据库中的表一般都是同种记录的"集合"(collection),所以API中的名词也应该使用复数。
例子
https://api.example.com/v1/products
https://api.example.com/v1/users
https://api.example.com/v1/employees

请求方式

  • GET(SELECT): 从服务器取出资源(一项或多项)。
  • POST(CREATE): 在服务器新建一个资源。
  • PUT(UPDATE): 在服务器更新资源(客户端提供改变后的完整资源)。
  • DELETE(DELETE): 从服务器删除资源。
 例子: 
 GET /v1/products 获取所有商品
 GET /v1/products/ID 获取某个指定商品的信息
 POST /v1/products 新建一个商品
 PUT /v1/products/ID 更新某个指定商品的信息
 DELETE /v1/products/ID 删除某个商品
 GET /v1/products/ID/purchases 列出某个指定商品的所有投资者
 GET /v1/products/ID/purchases/ID 获取某个指定商品的指定投资者信息

方法命名也要具有一定规范

  • 新增 以“add”为前缀。例如add{XXX}
  • 删除 以“delete”为前缀。例如delete{XXX}
  • 修改 以“updata”为前缀。例如updata{XXX}
  • 获取 以“get”为前缀。例如get{XXX}
  • 获取 以“get”为前缀、“List”为后缀。例如get{XXX}List
  • 保存 以“save”为前缀。例如save{XXX}
  • 发送 以“send”为前缀。例如send{XXX}
  • 上传 以“upload”为前缀。例如upload{XXX}

请求参数

  • cookie
  • request header: 可以存放requestId,token,加密字段等
  • 请求body数据 :针对入参数据,后端必须做数据验证
  • 地址栏参数

响应格式

response:

----------------------------------------

{
 status: 200, // 详见【status】
 data: {
 code: 1, // 详见【code】
 data: {} || [], // 数据
 message: '成功', // 存放响应信息提示,显示给客户端用户【须语义化中文提示】
 sysMessage: 'success' // 存放响应信息提示,调试使用,中英文都行
 ... // 其它参数,如 total【总记录数】等
 },
 msg: '成功', // 存放响应信息提示,显示给客户端用户【须语义化中文提示】
 sysMsg: 'success' // 存放响应信息提示,调试使用,中英文都行
}

status

200: OK 
400: Bad Request 
500:Internal Server Error 
401:Unauthorized 
403:Forbidden 
404:Not Found

code

 1: 获取数据成功 | 操作成功 
 0:获取数据失败 | 操作失败

前后端约定

后端

  • 后端需要保证JSON格式的合法性,前端不对格式的合法性做判断
  • 金额格式:所有金额以元为单位,显示性的后台返回的是格式化之后的,例如:6,800
  • 时间格式: 尽量以一致格式的字符串传递 2019-01-01 12:12:12
  • 数据接口中定义的key集合是后端返回的子集,即key不缺失(参考数据格式,允许传递更多数据)
  • key使用驼峰命名,首字母小写
  • 空对象请使用[]
  • 空列表请使用[]
  • 空字符串请使用''
  • 默认数字请使用0
  • 尽量避免使用null undefined
  • 响应头Content-Type为"Application/json; charset=UTF-8"
  • 接口应该携带requestId唯一标示用来追踪问题
  • 敏感度高的数据,客户端和服务器通过约定的算法,对传递的参数值进行签名匹配,防止参数在请求过程中被抓取篡改。
  • 包含用户隐私的字段数据,需要加*号。如:手机号,身份证,用户邮箱,支付账号,邮寄地址等。
 "phone":"150*****000",
 "idCard":"3500**********0555", 
 "email":"40*****00@qq.com" 

前端

  • 请求头 application/x-www-form-urlencoded
  • 请求字段使用驼峰命名,首字母小写
  • 一个页面尽量只有一个拉取接口,减少类似这种的连续请求。
  • 当请求需要缓存并且有需要及时更新的情况,可以分多个请求。

文档

这个无需多说,在系统对接的时候,有文档绝对是个福音。

  • 尽量采用自动化接口文档,可以做到在线测试,同步更新。
  • 应包含:接口BASE地址、接口版本、接口模块分类等。
  • 每个接口应包含: 接口地址:不包含接口BASE地址。 请求方式: get、post、put、delete等。 请求参数:数据格式【默认JSON、可选form data】、数据类型、是否必填、中文描述。 响应参数:类型、中文描述。
  • 特殊code映射码表

瘦客户端

客户端任何的修改都是需要发版的,发版需要审核流程。

  • 客户端尽量只负责展示逻辑,不处理业务逻辑
  • 客户端不处理金额的计算
  • 客户端少处理请求参数的校验与约束提示

接口日志

方便故障定位,错误重放,日志统计分析等

上传/下载

上传/下载,参数增加文件md5,用于完整性校验

性能优化

合并接口

字段简写

无用字段清理

图片裁剪

局部刷新

预加载

其他

接口安全,防参数篡改

频率的控制

数据存储

是否需要依赖于第三方

服务降级,熔断和限流

拆分

扩展性

适配性

幂等

重复提交

部署

缓存穿透、缓存雪崩和缓存击穿

是否需要白名单

预加载

重试

异步

服务端推送或者客户端拉取数据

隔离(例如内网的中台服务,后端服务)

健康检查,后台大盘监控可视化,故障主动通知



Tags:API   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
近日只是为了想尽办法为 Flask 实现 Swagger UI 文档功能,基本上要让 Flask 配合 Flasgger, 所以写了篇 Flask 应用集成 Swagger UI 。然而不断的 Google 过程中偶然间发现了...【详细内容】
2021-12-23  Tags: API  点击:(6)  评论:(0)  加入收藏
一个项目的大部分API,测试用例在参数和参数值等信息会有很多相似的地方。我们可以复制API,复制用例来快速生成,然后做细微调整既可以满足我们的测试需求1.复制API:在菜单发布单...【详细内容】
2021-12-14  Tags: API  点击:(20)  评论:(0)  加入收藏
10月18号, W3C中网络平台孵化器小组(Web Platform Incubator Community Group)公布了HTML Sanitizer API的规范草案。这份草案用来解决浏览器如何解决XSS攻击问题。 网络安全中...【详细内容】
2021-12-07  Tags: API  点击:(20)  评论:(0)  加入收藏
当我们通过kubectl来查看、修改Kubernetes资源时,有没有想过后面的接口到底是怎样的?有没有办法探查这些交互数据呢?Kuberenetes客户端和服务端交互的接口,是基于http协议的。所...【详细内容】
2021-11-23  Tags: API  点击:(29)  评论:(0)  加入收藏
前言客户端请求API,通常需要通过返回码来判断API返回的结果是否符合预期,以及该如何处理返回的内容等。相信很多同学都吃过返回码定义混乱的亏,有的API用返回码是int类型,有的是...【详细内容】
2021-10-28  Tags: API  点击:(52)  评论:(0)  加入收藏
凭借着平缓的学习曲线和简单直接的语法,Python在全球范围内的受欢迎程度,正在呈指数级增长。该编码语言往往可以被用于Web开发、软件开发、数学计算、系统脚本、以及几乎所有...【详细内容】
2021-09-22  Tags: API  点击:(48)  评论:(0)  加入收藏
Guava提供的RateLimiter可以限制物理或逻辑资源的被访问速率,咋一听有点像java并发包下的Samephore,但是又不相同,RateLimiter控制的是速率,Samephore控制的是并发量。RateLimit...【详细内容】
2021-09-17  Tags: API  点击:(72)  评论:(0)  加入收藏
前言前后端分离开发模式中,api文档是最好的沟通方式。今天就来说一说如何整合Swagger生成一套漂亮、美观、实用的接口文档。 源码传送门: https://gitee.com/huoqstudy/xiliu-...【详细内容】
2021-09-08  Tags: API  点击:(65)  评论:(0)  加入收藏
注:商业级功能效果演示,非开源,无源码。研发基础在之前AJAX请求数据加密效果之上,更进一步,对返回数据加密。之前是单纯用于登录场景。更广泛的场景是所有此类AJAX WEB API接口。...【详细内容】
2021-09-03  Tags: API  点击:(75)  评论:(0)  加入收藏
最近一连串的 API 安全事件(Peloton、Experian、Clubhouse 等)无疑迫使许多安全和开发团队仔细检查他们的 API 安全状况,以确保它们不会成为下一个被攻击对象。创建面向外部受...【详细内容】
2021-09-01  Tags: API  点击:(59)  评论:(0)  加入收藏
▌简易百科推荐
本文分为三个等级自顶向下地分析了glibc中内存分配与回收的过程。本文不过度关注细节,因此只是分别从arena层次、bin层次、chunk层次进行图解,而不涉及有关指针的具体操作。前...【详细内容】
2021-12-28  linux技术栈    Tags:glibc   点击:(3)  评论:(0)  加入收藏
摘 要 (OF作品展示)OF之前介绍了用python实现数据可视化、数据分析及一些小项目,但基本都是后端的知识。想要做一个好看的可视化大屏,我们还要学一些前端的知识(vue),网上有很多比...【详细内容】
2021-12-27  项目与数据管理    Tags:Vue   点击:(2)  评论:(0)  加入收藏
程序是如何被执行的  程序是如何被执行的?许多开发者可能也没法回答这个问题,大多数人更注重的是如何编写程序,却不会太注意编写好的程序是如何被运行,这并不是一个好...【详细内容】
2021-12-23  IT学习日记    Tags:程序   点击:(9)  评论:(0)  加入收藏
阅读收获✔️1. 了解单点登录实现原理✔️2. 掌握快速使用xxl-sso接入单点登录功能一、早期的多系统登录解决方案 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器...【详细内容】
2021-12-23  程序yuan    Tags:单点登录(   点击:(8)  评论:(0)  加入收藏
下载Eclipse RCP IDE如果你电脑上还没有安装Eclipse,那么请到这里下载对应版本的软件进行安装。具体的安装步骤就不在这赘述了。创建第一个标准Eclipse RCP应用(总共分为六步)1...【详细内容】
2021-12-22  阿福ChrisYuan    Tags:RCP应用   点击:(7)  评论:(0)  加入收藏
今天想简单聊一聊 Token 的 Value Capture,就是币的价值问题。首先说明啊,这个话题包含的内容非常之光,Token 的经济学设计也可以包含诸多问题,所以几乎不可能把这个问题说的清...【详细内容】
2021-12-21  唐少华TSH    Tags:Token   点击:(10)  评论:(0)  加入收藏
实现效果:假如有10条数据,分组展示,默认在当前页面展示4个,点击换一批,从第5个开始继续展示,到最后一组,再重新返回到第一组 data() { return { qList: [], //处理后...【详细内容】
2021-12-17  Mason程    Tags:VUE   点击:(14)  评论:(0)  加入收藏
什么是性能调优?(what) 为什么需要性能调优?(why) 什么时候需要性能调优?(when) 什么地方需要性能调优?(where) 什么时候来进行性能调优?(who) 怎么样进行性能调优?(How) 硬件配...【详细内容】
2021-12-16  软件测试小p    Tags:性能调优   点击:(20)  评论:(0)  加入收藏
Tasker 是一款适用于 Android 设备的高级自动化应用,它可以通过脚本让重复性的操作自动运行,提高效率。 不知道从哪里听说的抖音 app 会导致 OLED 屏幕烧屏。于是就现学现卖,自...【详细内容】
2021-12-15  ITBang    Tags:抖音防烧屏   点击:(25)  评论:(0)  加入收藏
11 月 23 日,Rust Moderation Team(审核团队)在 GitHub 上发布了辞职公告,即刻生效。根据公告,审核团队集体辞职是为了抗议 Rust 核心团队(Core team)在执行社区行为准则和标准上...【详细内容】
2021-12-15  InfoQ    Tags:Rust   点击:(25)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条