news 2026/4/10 20:24:25

RESTful API 请求和响应格式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
RESTful API 请求和响应格式

RESTful API 的请求和响应格式详解

在 RESTful API 中,请求和响应的格式设计直接影响 API 的易用性、一致性和可维护性。优秀的格式规范能让前后端开发者快速理解接口行为,减少沟通成本。

1. 总体原则
  • 内容类型统一:几乎全部使用JSON(application/json)作为请求和响应的数据格式。
  • 结构一致:成功响应和错误响应都采用统一的包裹结构,便于客户端统一处理。
  • 清晰、可读:字段命名规范,时间格式标准,返回必要元信息。
  • 避免裸数据:不要直接返回数组或单个对象,而是用包裹对象提供上下文。
2. 请求格式(Request)
2.1 常见 Content-Type
HTTP 方法典型 Content-Type说明
POST / PUT / PATCHapplication/json最常用,发送 JSON 数据
文件上传multipart/form-data上传头像、附件等
表单提交application/x-www-form-urlencoded传统表单(较少用)
2.2 请求体(Body)示例

创建用户(POST /users)

{"name":"张三","email":"zhang@example.com","password":"secret123","age":28,"roles":["user","admin"]}

部分更新用户(PATCH /users/123)

{"name":"张三丰","age":30}

(只包含需要修改的字段)

查询参数(Query Parameters)用于 GET 请求过滤

GET /articles?status=published&tag=rest&sort=-created_at&page=2&limit=20
2.3 请求头(Headers)常用字段
Header示例值说明
Content-Typeapplication/json请求体格式
Acceptapplication/json期望响应格式
AuthorizationBearer eyJhbGciOiJIUzI1NiIs…JWT 或其他认证令牌
X-API-Keyyour-api-keyAPI Key 认证
3. 响应格式(Response)
3.1 成功响应统一结构(推荐)

方案一:通用包裹(最常用)

{"data":{// 主要数据"id":123,"name":"张三","email":"zhang@example.com","created_at":"2025-12-25T10:00:00Z"},"meta":{// 元信息(可选)"timestamp":"2025-12-25T10:00:01Z","request_id":"abc123-def456"}}

方案二:集合响应(列表 + 分页)

{"data":[{"id":1,"title":"REST 教程"},{"id":2,"title":"API 设计"}],"meta":{"pagination":{"total":156,"page":2,"limit":20,"total_pages":8},"timestamp":"2025-12-25T10:00:01Z"}}

方案三:无数据内容(如 DELETE 成功)

  • 返回204 No Content(无响应体,最推荐)
  • 或返回 200 + 简单结构:
{"data":null,"meta":{"message":"用户删除成功"}}
3.2 错误响应统一结构(非常重要!)

推荐错误格式(Problem Details - RFC 7807 标准)

{"error":{"code":"VALIDATION_ERROR",// 业务错误码(字符串)"message":"请求参数验证失败",// 给开发者的友好提示"details":[// 具体字段错误(可选){"field":"email","issue":"already_exists","message":"该邮箱已被注册"},{"field":"age","issue":"invalid_range","message":"年龄必须在 18-100 之间"}]}}

响应头

  • Content-Type: application/json
  • HTTP 状态码:400 Bad Request、422 Unprocessable Entity 等

常见错误状态码与 code 对应

HTTP 状态码推荐 error.code场景
400BAD_REQUEST参数格式错误
401UNAUTHORIZED未登录
403FORBIDDEN无权限
404NOT_FOUND资源不存在
409CONFLICT资源冲突(如用户名重复)
422VALIDATION_ERROR业务校验失败(最常用)
429TOO_MANY_REQUESTS限流
500INTERNAL_SERVER_ERROR服务器异常
3.3 字段命名与数据格式规范
项目推荐规范示例
字段命名snake_case(下划线)或 camelCaseuser_iduserId(统一即可)
时间格式ISO 8601(UTC)“2025-12-25T10:00:00Z”
布尔值true / false“is_active”: true
空值null(避免空字符串)“description”: null
枚举字符串常量“status”: “published”
4. 完整示例对比

请求

POST /api/v1/users HTTP/1.1 Content-Type: application/json Authorization: Bearer xyz123... { "name": "李四", "email": "li@example.com", "password": "123456" }

成功响应(201 Created)

HTTP/1.1 201 Created Content-Type: application/json Location: /api/v1/users/456 { "data": { "id": 456, "name": "李四", "email": "li@example.com", "created_at": "2025-12-25T10:00:00Z" }, "meta": { "timestamp": "2025-12-25T10:00:01Z" } }

错误响应(422)

HTTP/1.1 422 Unprocessable Entity Content-Type: application/json { "error": { "code": "VALIDATION_ERROR", "message": "参数验证失败", "details": [ { "field": "email", "issue": "invalid_format", "message": "邮箱格式不正确" } ] } }
5. 总结口诀

请求简洁 JSON,响应统一包裹,错误结构化提示,状态码要准确

遵循这些格式规范,你的 RESTful API 将更加专业、一致,便于前端统一封装错误处理和数据解析。

如果你想看特定框架(如 Spring Boot、Express、FastAPI)的响应封装代码实现,或者 OpenAPI/Swagger 如何描述这些格式,欢迎继续问!

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

Turbo Editor完全攻略:从零开始的移动文本编辑指南

Turbo Editor完全攻略:从零开始的移动文本编辑指南 【免费下载链接】turbo-editor Simple and powerful File Editor for Android. All is licensed under the GPLv3 license. 项目地址: https://gitcode.com/gh_mirrors/tu/turbo-editor 你是否曾经在通勤路…

作者头像 李华
网站建设 2026/4/5 16:28:27

RESTful API 实际应用

RESTful API 的实际应用已经无处不在!从你每天用的手机 App 到大型电商平台,再到 AI 服务,几乎所有现代 Web 和移动应用都依赖 RESTful API 来实现前后端分离、数据交互和第三方集成。 下面用真实场景、流行案例和项目示例,带你看…

作者头像 李华
网站建设 2026/4/9 11:57:30

RESTful API 实践

RESTful API 实践指南:从零到上手一个完整项目 现在我们从理论转向真实实践!下面一步步带你实现一个简单的 TODO 任务管理 RESTful API(经典入门项目),支持增删改查、分页、认证等生产级特性。你可以选择 Node.js (Ex…

作者头像 李华
网站建设 2026/4/8 10:45:35

学术资源获取困境如何解决?Sci-Hub X Now终极方案详解

学术资源获取困境如何解决?Sci-Hub X Now终极方案详解 【免费下载链接】sci-hub-now 项目地址: https://gitcode.com/gh_mirrors/sc/sci-hub-now 还在为无法访问付费学术论文而苦恼吗?面对高昂的订阅费用和复杂的机构认证流程,无数研…

作者头像 李华
网站建设 2026/3/30 14:22:05

革命性集群自动化部署实战指南:从零构建企业级服务器矩阵

革命性集群自动化部署实战指南:从零构建企业级服务器矩阵 【免费下载链接】panel 耗子面板 - GO 开发的轻量 Linux 面板 项目地址: https://gitcode.com/GitHub_Trending/pane/panel 🚀 在数字化转型浪潮中,企业运维团队正面临前所未有…

作者头像 李华
网站建设 2026/4/9 22:42:36

Open-AutoGLM内测申请进行中,顶尖AI工具为何一码难求?

第一章:Open-AutoGLM内测申请进行中,顶尖AI工具为何一码难求? 近期,由智谱AI推出的全新自动化智能体框架 Open-AutoGLM 引发广泛关注。该工具基于 GLM 大模型构建,具备自主任务分解、工具调用与多轮决策能力&#xff0…

作者头像 李华