文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

构建强大REST API的十个最佳实践

2024-11-30 03:50

关注

1、使用具体且有意义的资源名称

选择能准确表示所代表实体的资源名称,而不要使用泛化或模糊的名称。

图片

这一条最佳实践非常明确,也就是说我们在使用REST API时,代表资源分类的部分,比如上图中的“users”和“customers”,使用users更泛化,不够具体,可能是To C的用户,也可能是To B或To G的用户。此时,最近确保定义的资源更具体,能够代表一定的清晰含义。

2、正确使用HTTP方法

根据不同的操作使用合适的HTTP方法(GET、POST、PUT、DELETE、PATCH等)。

图片

这一条涉及到HTTP方法的基本定义。举一个简单的例子来说明就是:一般提交表单操作,用POST请求,查询信息用GET请求。不要将两者颠掉或混用。当然,还有其他的HTTP方法,也是如此。

3、对API进行版本控制

使用版本控制确保向后兼容性,并允许在不破坏现有客户端的情况下进行未来的增强。

图片

为了保持版本的兼容性,依旧流量和功能的控制等,通常需要对API进行版本控制,这个是仅限于REST API,而是比较通用的一条最佳实践,特别是真的终端是APP的情况。

4、正确使用HTTP状态码

返回适当的HTTP状态码以指示API请求的成功或失败。

图片

这一条也是非常基础的HTTP知识,不同的错误码代表着不同的含义,准确的返回错误码,可以让终端更加精准的识别错误。

5、选择JSON字段命名约定

JSON标准没有强制规定字段命名约定,但最佳实践是选择一个并坚持使用。

图片

选择适合团队和编程语言的JSON命名规则,具体采用哪种不重要,重要的是整个团队要确保统一。在个人的团队中,更习惯使用驼峰(camelCase)的形式。

6、使用一致的错误信息

在大多数情况下,仅使用HTTP状态码无法解释出现的错误。为了帮助API使用者,包含一个结构化的JSON错误消息。这里的JSON错误信息更偏向业务层面。而HTTP状态码更偏向于HTTP交互层面。

响应应包括以下信息:

7、使用查询参数进行过滤、排序和搜索

查询参数允许你在HTTP请求的URL中提供额外的信息,以控制服务器返回的响应。

图片

8、实施身份验证和授权

通过实施适当的身份验证和授权机制来保护API。

建议:

9、不要维护状态

REST API不应在服务器上维护状态,这是客户端的责任。这很重要,因为它可以使API具备可缓存性、可扩展性,并使其与客户端解耦。

例如,电子商务API可能使用cookie来维护购物车的状态。然而,这种方法违反了RESTful API的关键原则:它们需要是无状态的。

10、文档化你的API

为你的API提供全面的文档,包括端点细节、请求/响应示例和使用指南。

建议:

来源:程序新视界内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯