RESTful API设计规范

简介: RESTful API设计规范

RESTful API设计规范


⼀、什么是RESTful?


⼜称REST(Representational State Transfer),⼀种软件架构⻛格、设计风格,而不是标准,只是提供了⼀组设计原则和约束条件。它主要⽤于客户端和服务器交互类的软件。


其核心是⾯向资源,REST专门针对网络应⽤设计和开发方式,以降低开发的复杂性,提⾼系统的可伸缩性。


在RESTful架构中,每个网址代表⼀种资源(resource),所以网址中不能有动词,只能有名词。


⼀般来说,数据库中的表都是同种记录的”集合”(collection),所以API中的名词也应该使⽤复数,除非没有合适的复数形式,如:weather。


二、设计概念和准则


  • 网络上的所有事物都可以被抽象为资源(resource);


  • 每个资源都有唯⼀的资源标识(resource identifier),对资源的操作不会改变这些标识;


  • 所有的操作都是无状态的;


  • 分层系统,表示组件⽆法了解它与之交互的中间层以外的组件。通过将系统知识限制在单个层,可以限制整个系统的复杂性,促进了底层的独⽴性。


三、为什么要使用RESTful API?


  • 面向资源(URI),具有解释性;


  • 行为(GET / POST / PUT / PATCH / DELETE)与资源(URI)分离,更加轻量;


  • 数据描述简单,使⽤JSON、XML、PROTOBUFFER即可全覆盖,主要使⽤JSON;


四、协议


API与⽤户的通信协议,⼀般使⽤HTTP协议,更安全情况下使⽤HTTPS。


五、域名


应该尽量将API部署在专⽤域名之下:


https://api.example.com


如果确定API很简单,不会有进⼀步扩展,可以考虑放在主域名下:


https://example.org/api/


六、版本


在每个API对应的URL中,应有⼀个版本号,以便将来服务升级后,所有版本的客户端可以正常使用,如下:


https://api.example.com/v1/topics/


https://api.example.com/v2/topics/


https://api.example.com/v3/topics/


七、http请求⽅式


image.png


八、路由(路径)


• 每个⽹址中不能有动词,只能有名词。并且应该使⽤复数,除⾮没有合适的复数形式,如:weather。


https://api.example.com/v1/topics/ —> 所有帖⼦


• 对于个体或个类名下资源,可以直接在路径上添加具体的id来表现,如下:


https://api.example.com/v1/topics/100001/info // id为100001的帖⼦的详情


https://api.example.com/v1/users/12345/topics/ // id为12345的⽤户名下所有帖⼦


• 更多例子[带请求方法]


[GET] https://api.example.com/v1/topics/ — 获取所有帖⼦(列表)


[POST] https://api.example.com/v1/topics/ — 新建帖⼦


[PUT] https://api.example.com/v1/topics/100001 — 更新完整帖⼦


[PATCH] https://api.example.com/v1/topics/100001 — 更新帖⼦部分信息


[DELETE] https://api.example.com/v1/topics/100001 — 删除帖⼦


[GET] https://api.example.com/v1/groups/1/topics/ — 获取某组所有帖⼦(列表)


[GET] https://api.example.com/v1/users/12345/profile — 获取某⽤户资料


[PUT] https://api.example.com/v1/users/12345/profile — 更新某⽤户资料


[GET] https://api.example.com/v1/users/12345/labels — 获取某⽤户所有标签


九、过滤信息(url中?后⾯的参数)


使用过滤信息的原因:


  1. 单⼀的 url 路径不能表现出所有的场景的,起到了补充作⽤;


?limit=10                   :指定返回记录的数量
?offset=10                  :指定返回记录的开始位置。
?page=2&per_page=100    :指定第⼏⻚,以及每⻚的记录数。
?sortby=name&order=asc    :指定返回结果按照哪个属性排序,以及排序顺序。
?animal_type_id=1           :指定筛选条件


  1. 避免多级 URL,不利于扩展,语义也不明确,理解困难;


多级URL:


GET /authors/12/categories/2 // 含义是什么?


正确做法是:


GET /authors/12?categories=2


十、状态码


HTTP 状态码就是⼀个三位数,分成五个类别:


image.png


除非是 500 和 404 错误,⼤部分使⽤ 200 状态码即可,返回的数据格式如下:



十一、 其它


(1)API的⾝份认证应该使用OAuth 2.0框架。


(2)服务器返回的数据格式,应该尽量使用JSON,避免使用XML。

相关文章
|
2月前
|
XML JSON API
识别这些API接口定义(http,https,api,RPC,webservice,Restful api ,OpenAPI)
本内容介绍了API相关的术语分类,包括传输协议(HTTP/HTTPS)、接口风格(RESTful、WebService、RPC)及开放程度(API、OpenAPI),帮助理解各类API的特点与应用场景。
|
4月前
|
监控 安全 API
电商API行业标准与规范体系构建:推动电商行业规范化前行
电商API行业标准与规范是推动电商高效发展的核心。通过数据格式标准化、接口设计一致性及严格的安全措施,可提升数据交互效率、保障安全并促进系统兼容性。淘宝、京东、拼多多等平台的实践展示了其重要性。未来,智能化、隐私保护强化和跨平台集成将成为主要趋势,助力电商生态持续繁荣。
|
4月前
|
人工智能 自然语言处理 API
电商API技术文档编写规范白皮书:方法论与行业实践
本文系统阐述电商API接口文档的编写规范与最佳实践,涵盖结构设计、技术语言、开发者体验、版本控制及质量保障等方面,助力企业提升开发效率,构建开放共赢的电商生态。
|
4月前
|
缓存 安全 API
RESTful与GraphQL:电商API接口设计的技术细节与适用场景
本文对比了RESTful与GraphQL这两种主流电商API接口设计方案。RESTful通过资源与HTTP方法定义操作,简单直观但可能引发过度或欠获取数据问题;GraphQL允许客户端精确指定所需字段,提高灵活性和传输效率,但面临深度查询攻击等安全挑战。从性能、灵活性、安全性及适用场景多维度分析,RESTful适合资源导向场景,GraphQL则适用于复杂数据需求。实际开发中需根据业务特点选择合适方案,或结合两者优势,以优化用户体验与系统性能。
|
4月前
|
JSON 编解码 API
Go语言网络编程:使用 net/http 构建 RESTful API
本章介绍如何使用 Go 语言的 `net/http` 标准库构建 RESTful API。内容涵盖 RESTful API 的基本概念及规范,包括 GET、POST、PUT 和 DELETE 方法的实现。通过定义用户数据结构和模拟数据库,逐步实现获取用户列表、创建用户、更新用户、删除用户的 HTTP 路由处理函数。同时提供辅助函数用于路径参数解析,并展示如何设置路由器启动服务。最后通过 curl 或 Postman 测试接口功能。章节总结了路由分发、JSON 编解码、方法区分、并发安全管理和路径参数解析等关键点,为更复杂需求推荐第三方框架如 Gin、Echo 和 Chi。
|
3月前
|
缓存 边缘计算 前端开发
从业务需求到技术栈:电商API选型RESTful还是GraphQL?这5个维度帮你决策
在数字经济时代,电商平台的竞争已延伸至用户体验与系统效能。作为连接前后端及各类服务的核心,API接口的架构设计至关重要。本文对比RESTful与GraphQL两大主流方案,从电商场景出发,分析两者的技术特性、适用场景与选型逻辑,帮助开发者根据业务需求做出最优选择。
|
3月前
|
监控 安全 测试技术
从0到1构建电商API:如何用规范设计省下百万维护成本?
本文系统解析电商API接口开发全流程,涵盖需求分析、架构设计、安全实践、测试上线及文档维护等关键环节,结合技术规范与实际案例,助力构建高可用、可扩展的电商系统。
|
3月前
|
缓存 供应链 监控
1688开放平台深度解析:商品详情API调用规范与性能优化策略
1688商品详情接口(alibaba.product.get)提供标准化数据获取方案,支持50+字段,涵盖商品基础信息、SKU详情、价格库存、图文视频资源。适用于电商比价、供应链管理、竞品分析及跨境信息同步,助力企业提升采购效率与市场响应速度。提供Python调用示例及常见问题解决方案,推荐使用本地缓存、异常重试机制和保险服务优化调用体验。
|
7月前
|
XML JSON API
Understanding RESTful API and Web Services: Key Differences and Use Cases
在现代软件开发中,RESTful API和Web服务均用于实现系统间通信,但各有特点。RESTful API遵循REST原则,主要使用HTTP/HTTPS协议,数据格式多为JSON或XML,适用于无状态通信;而Web服务包括SOAP和REST,常用于基于网络的API,采用标准化方法如WSDL或OpenAPI。理解两者区别有助于选择适合应用需求的解决方案,构建高效、可扩展的应用程序。
|
7月前
|
机器学习/深度学习 设计模式 API
Python 高级编程与实战:构建 RESTful API
本文深入探讨了使用 Python 构建 RESTful API 的方法,涵盖 Flask、Django REST Framework 和 FastAPI 三个主流框架。通过实战项目示例,详细讲解了如何处理 GET、POST 请求,并返回相应数据。学习这些技术将帮助你掌握构建高效、可靠的 Web API。