由于网络请求相关的最佳实践内容比较多,所以会拆分成三篇,分别是:
- 上篇:请求规范
- 中篇:Cookie、Session 及入参校验
- 下篇:浏览器插件的集成和使用
欢迎关注微信公众号“寂静小站”获取最新分享。
下面进入本篇正文,对于请求规范的最佳实践,将分三块来介绍:
- 为什么需要请求规范?
- 为什么不直接使用 Restful / GraphQL?
- FaasJS 请求规范
为什么需要请求规范?
网络请求有着多层的协议规范,但在最终应用层,由于业务形态等区别,并没有强制性的规范约束,这使得其有高度的灵活性,使用不当也会造成严重的混乱。
所以通常每个公司都会定制自己的内部和外部通讯的请求规范,通过规范来降低沟通成本和开发成本。
为什么不直接使用 Restful / GraphQL?
我们分开来看这两个规范。
Restful 是目前广泛流行的请求规范,使用请求方法作为动词,请求路径作为名词,把业务逻辑映射为对资源的操作,与面向对象的设计思想很接近。
但它有两个缺点:
- HTTP 方法的种类是固定的,并不完全适用于业务逻辑。一方面是有些业务难以抽象为某个 HTTP 方法,另一方面是如 PUT、PATCH 语义容易混淆;
- 把业务逻辑拆分为一个个资源,在某些场景下会使得拆分过细,增加了理解难度(如把登录行为映射成 POST /sessions)。
在前后端分离的背景下,GraphQL 给予了前端开发非常高的灵活性,且其 Query / Mutation 分离的方式,也很好地区分了对数据的查询和修改。我个人认为在非 Serverless 场景下,GraphQL 是目前最好的规范。
但在 Serverless 场景下,由于 Serverless 天生适合作为 BFF 层(甚至对于规模较小的业务,可以完全使用 Serverless 作为后端),前端开发也可以有足够的灵活性来自行创建和修改 API。
同时,在 Serverless 场景下,由于 GraphQL 的请求入口是单一的,这对入口云函数的稳定性要求很高,当其不可用时,可能会导致全部接口不可用。
FaasJS 请求规范
在 FaasJS 中,综合了 Restful、GraphQL 的优点,依照云函数的特点,形成了一套简单直观的请求规范。
其规定如下:
- 请求方法统一为 POST 方法
- 请求路径为云函数在项目中的文件路径
- 请求参数统一以 JSON 的格式放在 Body 中
- 响应统一返回为 JSON
- 操作成功的响应内容被包裹在 data 字段中
- 操作失败的失败原因被包裹在 error 字段中
这个请求规范的内在逻辑是:先将云函数们组织好,然后直接映射为 API 即可。
在 FaasJS 中,以文件夹作为天然的隔离方式,来区分和放置不同业务下的云函数。而在映射成 API 后,这种直观也同样传递了 API 层面。
此外,对于浏览器,虽然我们用的是 POST 方法,但可以在响应头中添加“Cache-Control”之类的缓存头来告知浏览器缓存。在某些有复杂查询条件的场景下,就不用担心查询条件过多达到浏览器 GET 请求长度限制的问题了。
最后,欢迎关注公众号“寂静小站”,与我交流讨论。