我们团队的接口规范

接口规范用来约束接口的一致性。一堆不统一的接口,不利于前后端代码复用,增加前后端接口联调成本,降低开发效率。

下面是我们团队的接口规范。

协议

为确保数据交互安全,正式地址用HTTPS协议。

接口url

  • 路径以 api 开始。如 /api/student/list
  • 路径中的英文字母使用小写字母。
  • 路径中的单词分隔用-

请求方法

  • 不改变数据的接口用 GET。如: 获取列表接口,详情接口。
  • 改变数据的接口用 POST。如: 新增接口,编辑接口,删除接口。

说明: 如果严格的按照HTTP方法的语义,新增接口应该用 PUT,删除接口应该用 DELETE。我们团队认为新增,删除接口均用 POST,易于记忆。这个细节,对整体的代码质量也没有影响。

请求参数

  • POST 的数据都会放在body里。用 x-www-form-urlencoded 格式。
  • token 放请求头中的 Authorization 字段。Authorization值的格式: Bearer token值
  • 接口版本 放请求头中的 Version 字段。

响应

返回json类型数据。如

{
  "errorCode": 0,
  "errorMsg": "",
  "data": {}// 或 []
}

说明:

  • errorCode: 错误码。errorCode 为
    • 0: 没有报错。
    • 401: 未登录或登录过期,需重新登录。
  • errorMsg: 错误信息。没有报错,不返回 errorMsg 字段。
  • data: 主体内容。对于列表接口,data 是数组类型的。
  • 响应字段用驼峰命名法。

列表接口

url

list 结尾。 如: /api/goods/list

请求方法

GET。

请求参数

筛选条件

筛选条件: where。where 的值是 encodeURIComponent(JSON.stringify({列名1: 值, 列名2: 值, ...}))。如: 筛选年龄(age)为20的学生,url 是 /api/student/list?where=%7B%22age%22%3A20%7D

列的筛选规则:

  • 精确搜索: 列名
  • 模糊搜索: 列名__like
  • 大于: 列名__gt。 用于数字和日期的列。
  • 大于等于: 列名__gte
  • 小于: 列名__lt
  • 小于等于: 列名__lte

分页信息

  • 页数: pageAt。
  • 每页的数量: pageLimit。

如: /api/student/list?pageAt=2&pageLimit=10

如果不传分页参数,默认返回第一页的10条数据。

排序信息

排序信息: order。order的值为: encodeURIComponent(JSON.stringify([{列名1: "asc(升序) 或 desc(降序)"}]))

支持多个排序值。

响应

{
  "errorCode": 0,
  "errorMsg": "",
  "data": [],
  "pager": {
    "pageAt": 1,// 当前页
    "total": 21// 总条数
  }
}

详情接口

url

detail/:id 结尾。 如: /api/goods/detail/3

请求方法

GET。

响应

{
  "errorCode": 0,
  "errorMsg": "",
  "data": {
    "id": 1,
    // 更多字段
  }
}

新增接口

url

add 结尾。 如: /api/goods/add

请求方法

POST。

响应

{
  "errorCode": 0,
  "errorMsg": "",
  "data": {
    "id": 1,
  }
}

data中的id为新增成功的数据的id。

编辑接口

url

edit/:id 结尾。如: /api/goods/edit/3

请求方法

POST。

响应

{
  "errorCode": 0,
  "errorMsg": "",
  "data": {}
}

删除接口

url

del/:id 结尾。如: /api/goods/del/3

请求方法

POST。

响应

{
  "errorCode": 0,
  "errorMsg": "",
  "data": {}
}

审核接口

url

audit/:id 结尾。如: /api/goods/audit/3

请求方法

POST。

响应

{
  "errorCode": 0,
  "errorMsg": "",
  "data": {}
}

接口文档要求

  • Postman 写。
  • 每个字段必须有备注。
  • 变化的值配置在环境中。如接口的域名。环境指一系列包含接口上下文变量的集合。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容

  • 总方针 构建易于理解和使用的RESTful接口。 接口应该是直观的,调用者可以通过接口来获得系统或应用程序中所有业...
    nikytwo阅读 1,843评论 0 3
  • 接口规范文档 具体内容如下: 一:协议规范 二:域名规范 三:版本控制规范 四:API路径规范 五:API命名规范...
    码课sir阅读 16,263评论 0 48
  • [toc] 1 概述 1.1 API的封装 zwan呼叫接口采用HTTP作为API接口。 1.2 消息格式规定 ...
    任传铭阅读 685评论 0 1
  • 简介 由于目前SRM移动应用API接口返回的的格式比较混乱,为了能够是确保API接口统一规范,定义以下规范,编写是...
    薪火设计阅读 1,232评论 0 1
  • 1. URI规范 不用大写 用 "-" 不用 "_" 参数列表要encode 资源集合,用复数形式表示 在REST...
    BigJeffWang阅读 2,223评论 0 50