对restful API一点简单的理解

1.rest是什么

rest的中文意思是表征性状态转移

在符合架构原理的前提下,理解和评估以网络为基础的应用软件的架构设计,来得到一个功能强,性能好,适宜通信的架构。REST即是一个架构的约束条件和原则

2.理解rest

rest这种理念,基本都是通过HTTP来实现的,自己平时写web路由层时会参考,所以也使用http相关的例子来加深自己的理解

3. URL设计优化

1.一般来说,URL会使用/来表示层级关系,gin-gonic为一级目录,gin为该目录下的一个仓库

https://github.com/gin-gonic
https://github.com/gin-gonic/gin

2.若其中一个层级的字数较多,则尽量使用_或-来加深URL的可读性

http://www.oschina.net/news/38119/oschina-translate-reward-plan

3.使用.或;来表示同级资源的关系,在git中,比较两个版本的不同会使用如下格式的URL,在对应的web路由层能够解析到这两个参数

http://demo/blocksha1/sha1.h/compare/e3af72cdafab5993d18fae056f87e1d675913d08;bd63e61bdf38e872d5215c07b264dcc16e4febca

4.若API版本变化比较大,那么加上版本是一个很好的做法

https://api.github.com/v3

5.统一资源接口

这个不难想象,例如,数据库操作一类/db,静态文件一类/static,也可以根据业务区分,例如,用户管理一类/user等等

资源分为单个文档和集合,尽量使用复数来表示资源,单个资源通过添加 id 或者 name 等来表示

http://...../getfile
http://...../getfile?id=1

6.使用正确的method

method 描述
HEAD 只获取某个资源的头部信息,比如只想了解某个文件的部分信息(文件大小,修改时间等)
GET 获取资源
POST 创建资源
PATCH 更新部分资源
PUT 整体替换资源
DELECT 删除资源

7.让数据库查询更加自由

在进行一些数据库sql查询的时候(推荐使用get),可以通过一些参数来使sql更加灵活自由

  • state:open,closed,all
  • since:查询指定时间之前或者指定时间之后的记录
  • sort:指定排序的字段
  • direction:排序的方向,升序ASC,降序DESC
  • page:分页查询时指定页数
  • pageSize:分页时每页显示的条数
  • ....

8.选择合适的状态码,参考https://httpstatuses.com/

状态码 解释
200 请求成功接收并处理,一般响应中都会有 body
201 请求已完成,并导致了一个或者多个资源被创建,最常用在 POST 创建资源的时候
202 请求已经接收并开始处理,但是处理还没有完成。一般用在异步处理的情况,响应 body 中应该告诉客户端去哪里查看任务的状态
204 请求已经处理完成,但是没有信息要返回,经常用在 PUT 更新资源的时候(客户端提供资源的所有属性,因此不需要服务端返回)。如果有重要的 metadata,可以放到头部返回
400 客户端发送的请求有错误(请求语法错误,body 数据格式有误,body 缺少必须的字段等),导致服务端无法处理
401 请求的资源需要认证,客户端没有提供认证信息或者认证信息不正确
403 服务端接收到并理解客户端的请求,但是客户端的权限不足,比如普通用户访问管理员权限的数据
404 客户端想要访问的资源不存在,链接失效或者客户端伪造URL的时候返回
405 服务端接收到请求,资源也存在,但不知道该访问方式
415 服务端不支持的客户端请求资源格式,一般是服务端要求content-type/content-encoding中的格式和客户端传输的不符
429 客户端在规定时间内请求次数过多,在进行访问限制时会用到
500 服务器内部错误,无法完成请求内容
503 服务器负荷过高或者维护,暂时无法提供服务,服务端应该返回Retry-After 头部,告诉客户端过一段时间再来重试

9.返回详细的错误信息

例如,客户端请求时发生错误,一般会返回4XX的错误code,但这个结果还是非常模糊,给出错误信息,能够让客户端快速定位问题,解决问题

10.验证和授权

一般接触到的api都涉及一定量的隐私数据,需要一定的权限来访问,例如,登陆后才能查看个人的资产,拥有管理员权限才可以查看后台的所有数据等等

例如用户登陆时,在验证用户名和密码时没有通过验证,则返回401,并相应的返回错误信息
若用户在登录后,查询某部分管理员数据后,出现权限不足的情况,则返回403,并相应的返回权限不足的错误信息

  • 需要注意的时,一些特殊的隐私URL,为了防止泄漏,在一些自动化试探用户的私有资源时,应该返回404,而不是返回403,返回403会暴露这些私有的URL资源

11.限流

常见的web服务都会用限流的措施,目的是防止滥用以及DDos攻击,在区块链中较为常见(因区块链处理单笔交易的速度有限,所以很容易造成区块链链上拥堵,引发区块链无法进行正常的业务)

在github中,普遍采用三个相关的头部,来传递限流的具体信息(可在单独一个方法中实现getRateLimit,也可在限流的请求接口中实现)

  • X-RateLimit-Limit:用户在指定时间内允许发送请求的最大值
  • X-RateLimit-Remaining:当前时间窗口剩下可用的请求数目
  • X-RateLimit-Rest:时间窗口重制的时候

对于超过流量的访问,一般返回429状态码too many request

12.Hypermedia API

在返回的结果中提供相关资源的链接
这种做法在前端/app端和后台进行资源交互时,比较常见,后端返回图片的URL,前端/app通过获取到的URL来加载资源,这样,在需要修改图片资源URL时,只需在后台修改即可,不需要前端/app端重新修改,可做到动态修改的目的

13.编写优秀的API文档

API文档非常关键,也非常比较,编写API文档时,需要做到信息的完整展示,API请求数据格式,相应数据格式,会出现的错误,限制条件,前提条件等等

良好的文档可以避免在开发中遇到的很多问题,前后端程序员之间的交流很大程度上也需要依靠api文档,总不能每写一个接口,都跑到你的座位上来问你一堆问题吧

参考自

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

推荐阅读更多精彩内容