news 2026/3/29 2:32:37

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/3/27 7:51:40

如何快速掌握JSONPath:面向开发者的完整查询指南

如何快速掌握JSONPath:面向开发者的完整查询指南 【免费下载链接】jsonpath-online-evaluator JSONPath Online Evaluator 项目地址: https://gitcode.com/gh_mirrors/js/jsonpath-online-evaluator 在现代数据驱动的开发环境中,高效处理JSON数据…

作者头像 李华
网站建设 2026/3/27 15:07:12

70万中文对联数据集实战应用全解析

70万中文对联数据集实战应用全解析 【免费下载链接】couplet-dataset Dataset for couplets. 70万条对联数据库。 项目地址: https://gitcode.com/gh_mirrors/co/couplet-dataset 对联数据集作为中文自然语言处理的重要资源,为seq2seq模型训练提供了丰富的语…

作者头像 李华
网站建设 2026/3/26 21:04:44

为什么你的Open-AutoGLM跑不起来?Mac环境配置常见问题TOP6详解

第一章:Open-AutoGLM mac部署在 macOS 系统上本地部署 Open-AutoGLM 可充分发挥其自动化代码生成与自然语言理解能力。该模型依赖 Python 环境及必要的深度学习框架支持,推荐使用 Conda 管理虚拟环境以避免依赖冲突。环境准备 确保已安装 Python 3.9 或更…

作者头像 李华
网站建设 2026/3/27 9:55:17

PaddlePaddle镜像与CI/CD流水线集成的方法论

PaddlePaddle镜像与CI/CD流水线集成的方法论 在AI模型日益频繁地进入生产环境的今天,一个棘手的问题始终困扰着算法工程师和运维团队:为什么本地训练好好的模型,一上服务器就报错?CUDA版本不匹配、Python依赖冲突、甚至某个库的微…

作者头像 李华
网站建设 2026/3/27 3:17:48

终极Google Drive下载实用手册:gdown完全指南

还在为Google Drive大文件下载烦恼吗?当你使用curl或wget时遇到安全警告无法下载,gdown就是你的救星。这个Python工具专门解决Google Drive下载难题,让你轻松掌握高效下载技巧。 【免费下载链接】gdown Download a large file from Google Dr…

作者头像 李华
网站建设 2026/3/23 4:56:52

中文分词实战:从入门到精通的全场景解决方案

中文分词实战:从入门到精通的全场景解决方案 【免费下载链接】pkuseg-python pkuseg多领域中文分词工具; The pkuseg toolkit for multi-domain Chinese word segmentation 项目地址: https://gitcode.com/gh_mirrors/pk/pkuseg-python 还在为中文文本处理中…

作者头像 李华