news 2026/6/10 17:12:18

HTTP 方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
HTTP 方法

RESTful API 中的 HTTP 方法详解

在 RESTful API 设计中,HTTP 方法(HTTP Verbs)是表达对资源操作意图的核心方式。不同的 HTTP 方法对应不同的语义,正确使用它们能让 API 更清晰、可预测和符合 REST 原则。

1. 核心 HTTP 方法及其在 REST 中的对应(CRUD 操作)
HTTP 方法对应 CRUD 操作主要用途是否安全(Safe)是否幂等(Idempotent)典型状态码(成功时)
GETRead获取资源(单个或集合)是(不修改资源)200 OK
POSTCreate创建新资源201 Created
PUTUpdate(替换)替换(全量更新)指定资源200 OK 或 201 Created
PATCHUpdate(部分)部分更新指定资源(只修改提供的字段)否(取决于实现)200 OK 或 204 No Content
DELETEDelete删除指定资源200 OK 或 204 No Content
2. 每个方法的详细说明与使用规范
  1. GET

    • 用于读取资源,不应产生副作用(不修改服务器状态)。
    • 支持查询参数(Query Parameters)进行过滤、分页、排序等。
    • 示例:
      • GET /users→ 获取用户列表
      • GET /users/123→ 获取 ID 为 123 的用户
      • GET /articles?tag=rest&limit=20&page=2→ 分页查询带标签的文章
    • 注意:GET 请求应可缓存,长度有限制(通常 < 2048 字符)。
  2. POST

    • 用于创建新资源,或执行非幂等的复杂操作(如触发流程)。
    • 请求体(Body)携带新资源数据。
    • 示例:
      • POST /users→ 创建新用户,返回 201 + Location 头部指向新资源 URI
      • POST /orders/123/pay→ (不推荐)触发支付(更推荐用资源方式设计)
    • 注意:多次相同 POST 会创建多个资源(非幂等)。
  3. PUT

    • 用于全量替换资源:如果资源不存在则创建(有时称为“upsert”),如果存在则完全替换。
    • 客户端必须提供资源的完整表示(缺失字段通常会被置为 null 或默认值)。
    • 示例:
      • PUT /users/123→ 用请求体完全替换 ID 为 123 的用户
    • 注意:多次相同 PUT 结果相同(幂等)。
  4. PATCH

    • 用于部分更新资源:只修改请求体中提供的字段,其他字段保持不变。
    • 常见格式:JSON Patch(RFC 6902)、JSON Merge Patch(RFC 7396)或自定义对象。
    • 示例:
      • PATCH /users/123→ Body:{ "name": "新名字" }只改名字
    • 注意:幂等性取决于实现(JSON Merge Patch 是幂等的,某些自定义方式不是)。
  5. DELETE

    • 用于删除资源。
    • 通常不需要请求体,可选返回被删除的资源表示。
    • 示例:
      • DELETE /users/123→ 删除 ID 为 123 的用户
    • 注意:多次相同 DELETE 结果相同(幂等),可返回 204 No Content。
3. 其他不常用但有用的 HTTP 方法
方法用途RESTful 中常见场景
HEAD与 GET 相同,但只返回头部(无响应体)检查资源是否存在、获取元信息(如 Last-Modified)
OPTIONS获取资源支持的 HTTP 方法CORS 预检请求、API 文档发现
TRACE回显请求(用于调试)很少使用,通常禁用以防安全风险
4. 安全(Safe)与幂等(Idempotent)的含义
  • 安全方法:不会改变服务器状态(只读)。只有GETHEAD是安全的。
  • 幂等方法:多次执行效果与一次相同。GET、PUT、DELETE、HEAD、OPTIONS是幂等的,POST 和 PATCH通常不是(PATCH 取决于具体实现)。

幂等性对网络重试、缓存、负载均衡非常重要。

5. 实际案例对比

假设资源是用户(/users/123):

操作推荐 HTTP 请求不推荐(RPC 风格)
获取用户信息GET /users/123POST /getUser
创建用户POST /usersGET /createUser
更新用户姓名PATCH /users/123{ “name”: “张三” }POST /updateUserName
完全替换用户信息PUT /users/123(完整用户对象)POST /replaceUser
删除用户DELETE /users/123POST /deleteUser
6. 总结口诀

“查用 GET,增用 POST,全改 PUT,部分 PATCH,删用 DELETE”

正确使用 HTTP 方法是设计优秀 RESTful API 的基础,它能让你的接口更直观、更易维护,也更符合业界标准。如果你想看具体代码示例(如 Express、Spring Boot 中的路由定义)或其他进阶话题(如批量操作如何选择方法),随时告诉我!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 10:49:20

RESTful API 进阶

RESTful API 进阶话题详解 掌握基础后&#xff0c;进阶阶段聚焦于成熟度提升、生产级架构、文档化、安全与性能优化&#xff0c;以及与其他技术的对比。以下是 2025 年最实用的进阶内容。 1. HATEOAS&#xff08;Hypermedia as the Engine of Application State&#xff09; …

作者头像 李华
网站建设 2026/6/10 12:25:53

终极指南:3步解决Gpredict卫星追踪的常见痛点[特殊字符]

你是否曾经遇到过这些问题&#xff1f;&#x1f4e1; 卫星信号时断时续&#xff0c;错过最佳通信窗口&#xff1f;面对复杂的轨道参数一头雾水&#xff1f;设备设置总是出问题&#xff1f;别担心&#xff0c;今天我们就来一一解决这些困扰无数卫星爱好者的难题&#xff01; 【免…

作者头像 李华
网站建设 2026/6/10 12:25:42

突破硬件壁垒:在Docker容器中运行macOS系统的完整实践指南

突破硬件壁垒&#xff1a;在Docker容器中运行macOS系统的完整实践指南 【免费下载链接】macos OSX (macOS) inside a Docker container. 项目地址: https://gitcode.com/GitHub_Trending/macos/macos 你是否曾因缺少苹果设备而无法体验macOS系统&#xff1f;或者需要在测…

作者头像 李华
网站建设 2026/6/10 12:35:32

深度解析MoveIt2:5大核心技术助你玩转机器人运动规划

深度解析MoveIt2&#xff1a;5大核心技术助你玩转机器人运动规划 【免费下载链接】moveit2 :robot: MoveIt for ROS 2 项目地址: https://gitcode.com/gh_mirrors/mo/moveit2 在机器人技术飞速发展的今天&#xff0c;机器人运动规划已成为智能机器人系统的核心能力。Mov…

作者头像 李华
网站建设 2026/6/10 14:17:14

GrasscutterTool 3.1.5:原神开发者的智能指令生成解决方案

GrasscutterTool 3.1.5&#xff1a;原神开发者的智能指令生成解决方案 【免费下载链接】GrasscutterTool-3.1.5 OMG,leak!!!! 项目地址: https://gitcode.com/gh_mirrors/gr/GrasscutterTool-3.1.5 在搭建原神私有服务器的过程中&#xff0c;开发者常常面临指令生成的效…

作者头像 李华
网站建设 2026/6/10 13:08:20

VRCX:重塑VRChat社交体验的智能管理平台

VRCX&#xff1a;重塑VRChat社交体验的智能管理平台 【免费下载链接】VRCX Friendship management tool for VRChat 项目地址: https://gitcode.com/GitHub_Trending/vr/VRCX 在VRChat的虚拟世界中&#xff0c;你是否曾因好友改名而认不出对方&#xff1f;是否因错过重要…

作者头像 李华