你知道80%的Web应用依赖于REST API进行无缝通信吗?然而,由于不当的设计选择,许多API无法正常运行。这里有一些建立可扩展、安全且对开发者友好的REST API的方法!
🚀 什么是REST API?
REST(表述性状态转移) 是一种设计网络应用的架构风格。一个遵循REST架构的API使用HTTP请求来执行标准操作,比如 GET(获取)、POST(新建)、PUT(更新)、DELETE(删除)。
这些API通常使用JSON进行通信,也会使用其他格式,比如XML。
🛠️ 优秀的 REST API 设计原则
优秀的 REST API 的关键是简洁明了。API 应该足够直观,让开发人员无需深入了解系统内部就能轻松理解。
2.1. 资源,而非行动
REST的核心理念是处理资源,每个资源都应该通过一个唯一的URI来获取,API应该围绕这些资源来设计。
// 这是一个不好的用法(获取用户详情的请求路径)
GET /getUserDetails
// 这是一个好的用法(获取用户信息的请求路径)
GET /users/{id}
点击全屏 退出全屏
在好的情況下,users
是一個資源,而 {id}
代表特定用戶的識別碼。
2.2. 使用恰当的HTTP方法
REST API 应该遵循 HTTP 标准,并使用适合每种操作的正确HTTP方法。
GET /users # 获取用户列表。
POST /users # 创建新用户。
GET /users/{id} # 通过ID获取用户。
PUT /users/{id} # 更新用户资料。
DELETE /users/{id} # 删除用户资料。
进入全屏退出全屏
请注意,GET
、PUT
和 DELETE
应该是幂等的,即多次执行相同效果,无论调用多少次结果都相同。相比之下,每次调用 POST
会生成一个新的资源。
2.3. 确保状态代码有意义
HTTP状态码能帮助你理解API请求的结果,这样更贴合中文中的日常交流风格。
+ 200 OK: 一切顺利
+ 201 Created: 资源已成功创建。
+ 204 No Content: 操作成功,但不返回数据。
- 400 Bad Request: 请求错误。
- 401 Unauthorized: 未授权。
- 404 Not Found: 未找到资源。
- 500 Internal Server Error: 服务器错误。
点击进入全屏,点击退出全屏。
2.4. 为您的API打上版本号
版本管理可以防止破坏性变更影响现有客户端。这样可以防止破坏性变更影响现有客户端,因为这种做法简单且被广泛使用。例如,使用/v1/
这样的路径。
2.5. 利用查询参数实现筛选、排序和分页
为了处理大规模数据集的检索,你应当通过查询参数来过滤、排序和分页显示结果,以处理结果。
过滤:
GET /users?role=admin
排序:
GET /users?sort=created_at,desc
分页:
GET /users?page=2&limit=20
切换到全屏模式,退出全屏
这些参数让使用者对他们检索到的数据有更多的控制。
📝 数据表示法
REST API 通常返回数据时使用 JSON 格式,这种格式轻量且易于操作。确保你的 JSON 响应保持一致性和可预测性。
3.1. 资源结构一致性
确保所有资源表示在所有端点上具有一致的结构。例如,如果多个端点返回 user
对象,其结构应保持一致。
{
"id": 123,
"name": "约翰多伊",
"email": "john.doe@example.com",
"created_at": "创建时间:2023-09-10T12:00:00Z"
}
点击全屏模式。要退出全屏了吗?
3.2. 错误处理
提供有意义且结构化的错误信息。当出现错误时,您的 API 应该返回相关的 HTTP 状态码和详细的错误提示。
{
"status": 400,
"error": "无效请求",
"message": "必填项 'email' 未提供。"
}
切换到全屏 退出全屏
🔒 身份验证与安全
4.1. 使用 HTTPS 协议.
请务必使用 HTTPS 来加密客户端和服务器的通信,确保数据完整且保密。
4.2. 基于令牌的认证
使用 OAuth 2.0 或 JWT(JSON Web 令牌) 进行无状态认证。基于令牌的认证确保敏感凭证,例如用户名和密码,不会在每次请求中传递。
授权令牌:Bearer <token>
全屏显示,退出全屏
RESTful URL 设计原则
你的URL应该清晰地反映资源层级。要让它们易读且简洁。
5.1 层级资源
如果有相关的资源,可以通过 URL 结构来展示它们的关系。
GET /users/{user_id}/订单列表
切换到全屏模式,退出全屏
这意味着你在为某个特定的用户查找订单。
5.2. 避免过多嵌套
避免使用深度嵌套的URL地址。如果资源在层级结构中相距太远,可以考虑将结构扁平化处理。
# 太复杂了
/companies/{company_id}/departments/{user_id}/orders/{order_id}
# 更好
/users/{user_id}/orders/{order_id}
注释: 下面的路径更简洁明了
【全屏模式】 【退出全屏】
📖 来看看我们的 API 相关文档
出色的 API 不可或缺的是优秀的文档。可以使用 Swagger/OpenAPI 这样的工具来自动生成文档。优秀的文档应当包含端点描述、请求和响应示例、认证信息以及错误处理细节。
⚡ 限速与限流
为了防止滥用,实施速率限制策略以控制客户端在特定的时间段内可以发起的请求数量。这可以防止您的 API 被压垮,并确保所有客户端的公平使用。
响应头信息如下:
X-Rate-Limit-Limit: 100
X-Rate-Limit-Remaining: 75
X-Rate-Limit-Reset: 1小时
全屏 退出全屏
🎯 结论
设计一个可扩展、安全且易于使用的REST API需要关注细节并遵循最佳做法。通过下述指南——例如使用正确的HTTP方法、有意义地构建URL路径、确保安全以及提供清晰的文档说明——你可以设计出开发者喜欢用的API。
构建一个高质量的API不仅仅是写出干净的代码;更在于提供一个用户可以信赖并理解的产品。持续迭代,收集反馈,并根据实际使用不断优化你的API。
你在做API开发吗?你在API开发中遇到了哪些难题?快来下面留言分享你的想法吧!⬇️🚀
[OOP]:面向对象编程
[CRUD]:创建、读取、更新、删除
[JVM]:Java虚拟机
[SUT]:被测系统
共同学习,写下你的评论
评论加载中...
作者其他优质文章