0

0

RESTful API设计规范详细解析与示例

雪夜

雪夜

发布时间:2025-07-13 18:16:02

|

377人浏览过

|

来源于php中文网

原创

restful api 设计的核心是围绕资源组织,使用标准 http 方法操作资源。1. 资源命名应使用名词,uri 使用斜杠分隔层级,避免扩展名,使用连字符提高可读性;2. http 方法对应操作:get 获取、post 创建、put 更新、delete 删除;3. 使用合适状态码如 200 成功、404 未找到等;4. 版本控制通过 uri 或请求头实现;5. hateoas 提供动态发现能力;6. 过滤排序使用查询参数,如 /users?name=john;7. 安全方面采用身份验证(如 jwt)、授权(如 rbac)、https、输入验证和速率限制;8. 文档使用 openapi 等标准化格式,提供详细描述和示例代码,并保持更新。

RESTful API设计规范详细解析与示例

RESTful API 设计,简单来说,就是让你的 API 看起来更像一个网站,资源有唯一的地址,用标准的方法(GET、POST、PUT、DELETE)来操作。关键在于“资源”和“状态转移”。

RESTful API设计规范详细解析与示例

解决方案

RESTful API 设计的核心在于围绕资源进行组织。每个资源都应该有一个唯一的 URI,并且客户端可以通过标准的 HTTP 方法来操作这些资源。

  1. 资源命名: 使用名词,而不是动词。例如,/users 表示用户资源,而不是 /getUsers
  2. URI 设计:
    • 使用斜杠 (/) 分隔资源层级,例如 /users/123/posts 表示用户 ID 为 123 的用户的帖子。
    • 避免在 URI 中使用文件扩展名,例如 .json.xml。通过 Content-Type 请求头来指定响应格式。
    • 使用连字符 (-) 分隔 URI 中的单词,提高可读性,例如 /user-posts
  3. HTTP 方法:
    • GET: 获取资源。
    • POST: 创建新资源。
    • PUT: 完整更新现有资源。
    • PATCH: 部分更新现有资源。
    • DELETE: 删除资源。
  4. 状态码: 使用合适的 HTTP 状态码来表示 API 请求的结果。例如:
    • 200 OK: 请求成功。
    • 201 Created: 资源创建成功。
    • 204 No Content: 请求成功,但没有返回内容。
    • 400 Bad Request: 客户端请求错误。
    • 401 Unauthorized: 未授权。
    • 403 Forbidden: 禁止访问。
    • 404 Not Found: 资源未找到。
    • 500 Internal Server Error: 服务器内部错误。
  5. 版本控制: 在 URI 中包含 API 版本号,例如 /v1/users。这样可以在不影响现有客户端的情况下,对 API 进行更新。或者使用自定义请求头 X-API-Version: 1
  6. HATEOAS (Hypermedia as the Engine of Application State): 在 API 响应中包含指向其他相关资源的链接。这使得客户端可以动态地发现 API 的功能,而无需硬编码 URI。

如何处理复杂的过滤和排序需求?

对于列表资源的过滤和排序,可以使用查询参数。例如:

RESTful API设计规范详细解析与示例
  • /users?name=john&age=30: 过滤出名字为 john 且年龄为 30 的用户。
  • /users?sort=age&order=desc: 按照年龄降序排序用户。
  • /users?page=2&limit=10: 分页查询,每页 10 条数据,查询第二页。

需要注意的是,对于复杂的过滤条件,可能需要考虑使用更高级的查询语言,例如 GraphQL。

如何处理 API 的安全性问题?

安全性是 API 设计中非常重要的一环。以下是一些常见的安全措施:

雾象
雾象

WaytoAGI推出的AI动画生成引擎

下载
RESTful API设计规范详细解析与示例
  • 身份验证 (Authentication): 验证客户端的身份。常见的身份验证方式包括:
    • Basic Authentication: 将用户名和密码进行 Base64 编码后放在 Authorization 请求头中。不安全,不推荐使用。
    • API Keys: 为每个客户端分配一个唯一的 API Key,客户端在请求时将 API Key 放在请求头或查询参数中。
    • OAuth 2.0: 一种授权框架,允许第三方应用访问用户的资源,而无需获取用户的密码。
    • JWT (JSON Web Token): 一种基于 JSON 的开放标准,用于在客户端和服务器之间安全地传输信息。
  • 授权 (Authorization): 确定客户端是否有权访问特定的资源。常见的授权方式包括:
    • 基于角色的访问控制 (RBAC): 为用户分配角色,并为角色分配权限。
    • 基于属性的访问控制 (ABAC): 根据用户的属性、资源的属性和环境的属性来决定是否允许访问。
  • HTTPS: 使用 HTTPS 加密客户端和服务器之间的通信,防止数据被窃听。
  • 输入验证: 对客户端提交的数据进行验证,防止恶意输入。
  • 速率限制: 限制客户端的请求频率,防止 API 被滥用。

例如,使用 JWT 的一个简单示例 (Python + Flask):

import jwt
import datetime
from functools import wraps
from flask import Flask, request, jsonify, make_response

app = Flask(__name__)
app.config['SECRET_KEY'] = 'your_secret_key' # 实际应用中应使用更强的密钥

def token_required(f):
    @wraps(f)
    def decorated(*args, **kwargs):
        token = request.headers.get('Authorization')

        if not token:
            return jsonify({'message': 'Token is missing!'}), 401

        try:
            data = jwt.decode(token, app.config['SECRET_KEY'], algorithms=["HS256"])
            # 在这里可以根据 data['user'] 查询用户信息,并传递给被装饰的函数
        except:
            return jsonify({'message': 'Token is invalid!'}), 401

        return f(*args, **kwargs)
    return decorated

@app.route('/login')
def login():
    auth = request.authorization

    if not auth or not auth.username or not auth.password:
        return make_response('Could not verify', 401, {'WWW-Authenticate': 'Basic realm="Login Required"'})

    # 在这里验证用户名和密码
    if auth.username == 'test' and auth.password == 'password':
        token = jwt.encode({
            'user': auth.username,
            'exp': datetime.datetime.utcnow() + datetime.timedelta(minutes=30)
        }, app.config['SECRET_KEY'], algorithm="HS256")

        return jsonify({'token': token})

    return make_response('Could not verify', 401, {'WWW-Authenticate': 'Basic realm="Login Required"'})

@app.route('/protected')
@token_required
def protected():
    return jsonify({'message': 'This is a protected route!'})

if __name__ == '__main__':
    app.run(debug=True)

如何设计良好的 API 文档?

清晰、完整的 API 文档对于 API 的使用者来说至关重要。以下是一些建议:

  • 使用标准化的文档格式: 例如 OpenAPI (Swagger) 或 RAML。这些格式可以自动生成 API 文档,并提供交互式的 API 测试界面。
  • 提供详细的资源描述: 描述每个资源的 URI、HTTP 方法、请求参数、响应格式和状态码。
  • 提供示例代码: 提供各种编程语言的示例代码,方便 API 使用者快速上手。
  • 保持文档更新: 随着 API 的更新,及时更新文档。

例如,使用 Swagger 的一个简单示例 (YAML):

openapi: 3.0.0
info:
  title: User API
  version: v1
paths:
  /users:
    get:
      summary: Get all users
      responses:
        '200':
          description: Successful operation
          content:
            application/json:
              schema:
                type: array
                items:
                  type: object
                  properties:
                    id:
                      type: integer
                    name:
                      type: string
  /users/{id}:
    get:
      summary: Get a user by ID
      parameters:
        - name: id
          in: path
          required: true
          schema:
            type: integer
      responses:
        '200':
          description: Successful operation
          content:
            application/json:
              schema:
                type: object
                properties:
                  id:
                    type: integer
                  name:
                    type: string

这个 YAML 文件可以被 Swagger UI 解析,生成交互式的 API 文档。

总而言之,RESTful API 设计不仅仅是一种技术规范,更是一种设计哲学。它强调资源的重要性,并通过标准的 HTTP 方法来操作这些资源。一个好的 RESTful API 应该易于理解、易于使用、易于维护,并且具有良好的安全性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python Flask框架
Python Flask框架

本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

104

2025.08.25

Python Flask Web框架与API开发
Python Flask Web框架与API开发

本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

81

2025.12.15

PHP API接口开发与RESTful实践
PHP API接口开发与RESTful实践

本专题聚焦 PHP在API接口开发中的应用,系统讲解 RESTful 架构设计原则、路由处理、请求参数解析、JSON数据返回、身份验证(Token/JWT)、跨域处理以及接口调试与异常处理。通过实战案例(如用户管理系统、商品信息接口服务),帮助开发者掌握 PHP构建高效、可维护的RESTful API服务能力。

179

2025.11.26

Python GraphQL API 开发实战
Python GraphQL API 开发实战

本专题系统讲解 Python 在 GraphQL API 开发中的实际应用,涵盖 GraphQL 基础概念、Schema 设计、Query 与 Mutation 实现、权限控制、分页与性能优化,以及与现有 REST 服务和数据库的整合方式。通过完整示例,帮助学习者掌握 使用 Python 构建高扩展性、前后端协作友好的 GraphQL 接口服务,适用于中大型应用与复杂数据查询场景。

23

2026.01.21

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

547

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

335

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号