前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Serverless 最佳实践之网络请求(上)

Serverless 最佳实践之网络请求(上)

作者头像
朱峰
发布2019-11-11 18:42:38
7610
发布2019-11-11 18:42:38
举报
文章被收录于专栏:寂静小站

由于网络请求相关的最佳实践内容比较多,所以会拆分成三篇,分别是:

  • 上篇:请求规范
  • 中篇:Cookie、Session 及入参校验
  • 下篇:浏览器插件的集成和使用

欢迎关注微信公众号“寂静小站”获取最新分享。

下面进入本篇正文,对于请求规范的最佳实践,将分三块来介绍:

  1. 为什么需要请求规范?
  2. 为什么不直接使用 Restful / GraphQL?
  3. FaasJS 请求规范

为什么需要请求规范?

网络请求有着多层的协议规范,但在最终应用层,由于业务形态等区别,并没有强制性的规范约束,这使得其有高度的灵活性,使用不当也会造成严重的混乱。

所以通常每个公司都会定制自己的内部和外部通讯的请求规范,通过规范来降低沟通成本和开发成本。

为什么不直接使用 Restful / GraphQL?

我们分开来看这两个规范。

Restful 是目前广泛流行的请求规范,使用请求方法作为动词,请求路径作为名词,把业务逻辑映射为对资源的操作,与面向对象的设计思想很接近。

但它有两个缺点:

  1. HTTP 方法的种类是固定的,并不完全适用于业务逻辑。一方面是有些业务难以抽象为某个 HTTP 方法,另一方面是如 PUT、PATCH 语义容易混淆;
  2. 把业务逻辑拆分为一个个资源,在某些场景下会使得拆分过细,增加了理解难度(如把登录行为映射成 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 请求长度限制的问题了。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-11-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 寂静小站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档