”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > REST API 设计和命名约定指南

REST API 设计和命名约定指南

发布于2024-11-06
浏览:980

Guide to REST API Design and Naming Conventions

有效地设计RESTful API对于创建可扩展、可维护且易于使用的系统至关重要。虽然存在某些标准,但许多标准并不是严格的规则,而是指导 API 设计的最佳实践。一种广泛使用的 API 架构模式是 MVC(模型-视图-控制器),但它本身并不能解决 API 设计的更精细方面,例如命名和结构。在本文中,我们将逐步介绍构建 REST API 的基本准则。

  1. 命名约定和面向资源的设计 API 通常是围绕资源定义的,资源代表系统中的实体,例如“用户”、“产品”或“订单”。资源可以是单个项目或集合,API 应提供直观且清晰的方式与这些资源进行交互。

关键原则:
面向资源:围绕资源而不是操作设计 API。资源应该被视为名词,而不是动词。例如:

/users 用于访问用户集合。
/users/{userId} 用于访问特定用户。
一致性:API 应该直观。如果用户可以从 /users 获取资源列表,他们应该期望能够通过添加标识符来获取单个资源:/users/{userId}.

集合与单一资源:

资源集合由复数名词表示:/users、/products。
单个资源通过附加该资源的唯一标识符来表示:/users/{userId}、/products/{productId}.

  1. HTTP 方法定义操作,而不是 URI 正在执行的操作(无论是检索数据、创建新条目还是更新现有数据)不应嵌入 URI 中。相反,HTTP 方法决定操作。

常见的 HTTP 方法及其用例:
GET:从服务器检索数据。

示例:GET /products 返回所有产品的列表。
示例: GET /users/{userId} 检索具有指定 userId 的用户。
POST:在服务器上创建新资源。

示例:POST /users 创建一个新用户。
PUT:用新数据替换现有资源(完全更新)。

示例:PUT /users/{userId} 将用户的数据完全替换为新数据。
PATCH:部分更新现有资源(部分更新)。

示例:PATCH /users/{userId} 仅更新指定的属性,例如电话号码。
DELETE:删除资源。

示例:DELETE /users/{userId} 删除指定 userId 的用户。

  1. REST 中的无状态性 REST API 应该是无状态的,这意味着每个 API 调用都必须包含服务器处理请求所需的所有信息。这确保每个请求都是自给自足的并且不依赖于先前的请求。

示例:当发出 GET 请求来获取用户详细信息时,该请求必须包含所需的授权令牌,即使先前的请求已经对用户进行了身份验证。这在分布式系统中至关重要,因为不同的请求可能会到达不同的服务器。

  1. 避免特定于服务器的数据存储 任何单个 API 请求都不应依赖于在特定服务器上存储临时数据。在分布式系统中,传入请求可能会路由到任何服务器,因此无论哪个服务器处理请求,都应该实现相同的结果。这就是为什么会话状态不应存储在单独的服务器上。

解决方案:对于会话管理,使用集中式或分布式存储系统(如 Redis)或无状态身份验证机制(如 JWT(JSON Web Token))。

  1. 资源与数据库表 您的 API 设计不应在数据库表和 API 端点之间具有一对一的映射。 API 应公开逻辑上有意义的资源,这些资源可以组合来自多个表或源的数据。

例子:
GET /orders/{orderId} 可能会检索订单详细信息,结合订单、order_items 和客户表中的信息。

  1. 数据类型的灵活性 REST API 不受数据库的数据类型或表结构的限制。您可以以最适合您的 API 消费者的方式构建您的响应。虽然 JSON 是最常用的格式,但如果需要,您可以自由返回 XML 或 CSV 等其他格式的数据。

示例:GET /reports/{reportId} 端点可能会根据请求中的查询参数或标头返回各种格式(JSON、CSV、PDF)的报告。
API 结构示例
为了将所有这些原则联系在一起,这里有一个遵循这些最佳实践的 API 结构示例:

GET /products:检索所有产品。
GET /products/{productId}:检索特定产品的详细信息。
POST /products:创建新产品。
PUT /products/{productId}:将产品替换为productId。
PATCH /products/{productId}:部分更新产品。
DELETE /products/{productId}:删除产品。
在这种结构中,资源被明确定义,HTTP 方法指定要采取的操作,确保 API 干净直观。

**结论
**设计 RESTful API 不仅仅涉及创建路由和处理 HTTP 方法。通过关注资源、利用 HTTP 方法进行操作并遵守无状态性,您可以创建直观、可维护和可扩展的 API。请记住,API 应该灵活且独立于特定的数据库结构,以便随着系统的发展提供更多的适应性。

遵循这些约定可确保您的 API 设计既高效又用户友好,从而最终增强 API 开发人员和消费者的体验。

版本声明 本文转载于:https://dev.to/rahul_ranjan_7200/guide-to-rest-api-design-and-naming-conventions-46co?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 哪种方法计算数据库行数更快:PDO::rowCount 或 COUNT(*)?为什么?
    哪种方法计算数据库行数更快:PDO::rowCount 或 COUNT(*)?为什么?
    PDO::rowCount 与 COUNT(*) 性能在数据库查询中计算行数时,选择使用 PDO:: rowCount 和 COUNT(*) 会显着影响性能。PDO::rowCountPDO::rowCount 返回受最后一个 SQL 语句影响的行数。但是,对于 SELECT 语句,某些数据库可能会...
    编程 发布于2024-11-06
  • PART# 使用 HTTP 进行大型数据集的高效文件传输系统
    PART# 使用 HTTP 进行大型数据集的高效文件传输系统
    让我们分解提供的HTML、PHP、JavaScript和CSS代码对于分块文件上传仪表板部分。 HTML 代码: 结构概述: Bootstrap for Layout:代码使用 Bootstrap 4.5.2 创建一个包含两个主要部分的响应式布局: 分块上传部分:用于...
    编程 发布于2024-11-06
  • 比较:Lithe 与其他 PHP 框架
    比较:Lithe 与其他 PHP 框架
    如果您正在为下一个项目探索 PHP 框架,很自然会遇到 Laravel、Symfony 和 Slim 等选项。但是,是什么让 Lithe 与这些更强大、更知名的框架区分开来呢?以下是一些突出 Lithe 如何脱颖而出的注意事项。 1. 轻量级和性能 Lithe 的设计重点关注轻量级架...
    编程 发布于2024-11-06
  • 编码风格指南:编写简洁代码的实用指南
    编码风格指南:编写简洁代码的实用指南
    在过去的五年里,我一直在不断尝试提高我的编码技能,其中之一就是学习和遵循最推荐的编码风格。 本指南旨在帮助您编写一致且优雅的代码,并包含一些提高代码可读性和可维护性的建议。它的灵感来自于社区中最受接受的流行指南,但进行了一些修改以更适合我的喜好。 值得一提的是,我是一名全栈 JavaScript 开...
    编程 发布于2024-11-06
  • 检查类型是否满足 Go 中的接口
    检查类型是否满足 Go 中的接口
    在Go中,开发人员经常使用接口来定义预期的行为,使代码灵活且健壮。但是如何确保类型真正实现接口,尤其是在大型代码库中? Go 提供了一种简单有效的方法来在编译时验证这一点,防止运行时错误的风险并使您的代码更加可靠和可读。 您可能见过类似的语法 var _ InterfaceName = TypeN...
    编程 发布于2024-11-06
  • 掌握 JavaScript 中的 &#this&# 关键字
    掌握 JavaScript 中的 &#this&# 关键字
    JavaScript 中的 this 关键字如果不理解的话可能会非常棘手。这是即使是经验丰富的开发人员也很难轻松掌握的事情之一,但一旦你掌握了,它可以为你节省大量时间。 在本文中,我们将了解它是什么、它在不同情况下如何工作以及使用它时不应陷入的常见错误。 在 JavaScript ...
    编程 发布于2024-11-06
  • PHP 中的用户浏览器检测可靠吗?
    PHP 中的用户浏览器检测可靠吗?
    使用 PHP 进行可靠的用户浏览器检测确定用户的浏览器对于定制 Web 体验至关重要。 PHP 提供了两种可能的方法: $_SERVER['HTTP_USER_AGENT'] 和 get_browser() 函数。$_SERVER['HTTP_USER_AGENT']...
    编程 发布于2024-11-06
  • 增强您的 Web 动画:像专业人士一样优化 requestAnimationFrame
    增强您的 Web 动画:像专业人士一样优化 requestAnimationFrame
    流畅且高性能的动画在现代 Web 应用程序中至关重要。然而,管理不当可能会使浏览器的主线程过载,导致性能不佳和动画卡顿。 requestAnimationFrame (rAF) 是一种浏览器 API,旨在将动画与显示器的刷新率同步,从而确保与 setTimeout 等替代方案相比更流畅的运动。但有效...
    编程 发布于2024-11-06
  • 为什么MySQL服务器在60秒内就消失了?
    为什么MySQL服务器在60秒内就消失了?
    MySQL 服务器已消失 - 恰好在 60 秒内在此场景中,之前成功运行的 MySQL 查询现在遇到了60 秒后超时,显示错误“MySQL 服务器已消失”。即使调整了 wait_timeout 变量,问题仍然存在。分析:超时正好发生在 60 秒,这表明是设置而不是资源限制是原因。直接从 MySQL ...
    编程 发布于2024-11-06
  • 为什么带有“display: block”和“width: auto”的按钮无法拉伸以填充其容器?
    为什么带有“display: block”和“width: auto”的按钮无法拉伸以填充其容器?
    了解具有“display: block”和“width: auto”的按钮的行为当您设置“display: block”时一个按钮,它会调整其布局以占据可用的整个宽度。但是,如果将其与“width: auto”结合使用,则按钮会出现意外行为,并且无法拉伸以填充其容器。此行为源于按钮作为替换元素的基本...
    编程 发布于2024-11-06
  • 为 Bluesky Social 创建机器人
    为 Bluesky Social 创建机器人
    How the bot will work We will develop a bot for the social network Bluesky, we will use Golang for this, this bot will monitor some hashtags ...
    编程 发布于2024-11-06
  • 为什么 PHP 的浮点运算会产生意外的结果?
    为什么 PHP 的浮点运算会产生意外的结果?
    PHP 中的浮点数计算精度:为什么它很棘手以及如何克服它在 PHP 中处理浮点数时,这一点至关重要了解其固有的准确性限制。如代码片段所示:echo("success");} else {echo("error");} 您可能会惊讶地发现,尽管值之间的差异小于 ...
    编程 发布于2024-11-06
  • Python中可以通过变量ID逆向获取对象吗?
    Python中可以通过变量ID逆向获取对象吗?
    从 Python 中的变量 ID 检索对象引用Python 中的 id() 函数返回对象的唯一标识。人们很容易想知道是否可以反转此过程并从其 ID 获取对象。具体来说,我们想要检查取消引用变量的 ID 是否会检索原始对象:dereference(id(a)) == a理解解引用的概念及其在 Pyth...
    编程 发布于2024-11-06
  • Go 的 Defer 关键字如何在函数执行顺序中发挥作用?
    Go 的 Defer 关键字如何在函数执行顺序中发挥作用?
    了解 Go 的 Defer 关键字的功能使用 Go 时,了解 defer 关键字的行为至关重要。该关键字允许开发人员推迟函数的执行,直到周围的函数返回。但是,需要注意的是,函数的值和参数在执行 defer 语句时进行评估。示例:评估 Defer Order为了说明这一点,请考虑以下内容代码:pack...
    编程 发布于2024-11-06
  • WordPress Gutenberg 全局状态管理初学者指南
    WordPress Gutenberg 全局状态管理初学者指南
    构建复杂的 WordPress 块编辑器 (Gutenberg) 应用程序时,有效管理状态变得至关重要。这就是 @wordpress/data 发挥作用的地方。它允许您跨 WordPress 应用程序中的不同块和组件管理和共享全局状态。 如果您不熟悉管理全局状态或使用@wordpress/data,...
    编程 发布于2024-11-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3