rest api是什么_什么是REST?什么是RESTful?

本文详细解析REST架构原理,介绍了如何设计RESTful风格API,包括路径设计、HTTP动词选择,并分享了RESTful API的最佳实践。适合理解API设计者和开发者阅读。
557becfcf347cd47b7c605e7ff3f311a.png

一、REST来源

REST:是一组架构约束条件和原则,REST是Roy Thomas Fielding在他2000年的博士论文中提出的。 Roy Thomas Fielding是HTTP协议(1.0版和1.1版)的主要设计者、Apache服务器作者之一、Apache基金会第一任主席

二、什么是REST

REST(Representational State Transfer):表现层状态转移,一种软件架构风格,不是标准。既然不是标准,我可以遵守,也可以不遵守!!! 什么是表现层状态转移:

Representational (表现层) State Transfer(状态转移):通过HTTP动词实现。
  • 总结:URL定位资源,HTTP动词(GET,POST,PUT,DELETE)描述操作。

三、什么是RESTful

基于REST构建的API就是RESTful风格

四、如何设计RESTful风格的API

1.路径设计

在RESTful架构中,每个网址代表一种资源(resource),所以网址中不能有动词,只能有名词,而且所用的名词往往与数据库的表名对应,一般来说,数据库中的表都是同种记录的”集合”(collection),所以API中的名词也应该使用复数。 举例来说,有一个API提供动物园(zoo)的信息,还包括各种动物和雇员的信息,则它的路径应该设计成下面这样。

   https://api.example.com/v1/zoos    https://api.example.com/v1/animals    https://api.example.com/v1/employees

2.HTTP动词设计

对于资源的具体操作类型,由HTTP动词表示,常用的HTTP动词如下:

请求方式含义GET获取资源(一项或多项)POST新建资源PUT更新资源(客户端提供改变后的完整资源)DELETE删除资源

如何通过URL和http动词获悉要调用的功能:

请求方式含义GET/zoos列出所有动物园POST/zoos新建一个动物园GET/zoos/ID获取某个指定动物园的信息PUT/zoos/ID更新某个指定动物园的信息(提供该动物园的全部信息)DELETE/zoos/ID删除某个动物园GET/zoos/ID/animals列出某个指定动物园的所有动物DELETE/zoos/ID/animals/ID删除某个指定动物园的指定动物

RESTFul API的一些最佳实践原则:

  1. 使用HTTP动词表示增删改查资源, GET:查询,POST:新增,PUT:更新,DELETE:删除
  2. 返回结果必须使用JSON
  3. HTTP状态码,在REST中都有特定的意义:200,201,202,204,400,401,403。比如401表示用户身份认证失败,403表示你验证身份通过了,但这个资源你不能操作。
  4. 如果出现错误,返回一个错误码: 10000=通用参数错误10001=资源未找到
  5. API 必须有版本的概念, v1, v2
  6. 使用Token令牌来做用户身份的校验与权限分级
  7. url中大小写不敏感,不要出现大写字母
  8. 使用中划线而不是使用下划线做URL路径中字符串连接
  9. 有一份漂亮的文档

RESTFul API好用吗?

某些情况好用,某些情况不好用。什么情况好用,什么情况不好用呢?

  1. 一个经验性的总结:对于开放的API,比如豆瓣、新浪微博、GitHub,好用,非常合适
  2. 对于内部开发,不好用
  3. REST是一种软件架构风格,不是标准。既然不是标准,可以遵守,也可以不遵守!

结论

实践过程中开发人员灵活把握

【博士论文复现】【阻抗建模、验证扫频法】光伏并网逆变器扫频与稳定性分析(包含锁相环电流环)(Simulink仿真实现)内容概要:本文档围绕“博士论文复现”主题,重点介绍了光伏并网逆变器的阻抗建模与扫频法稳定性分析,涵盖锁相环电流环的Simulink仿真实现。文档旨在通过完整的仿真资源代码帮助科研人员复现相关技术细节,提升对新能源并网系统动态特性稳定机制的理解。此外,文档还提供了大量其他科研方向的复现资源,包括微电网优化、机器学习、路径规划、信号处理、电力系统分析等,配套MATLAB/Simulink代码与模型,服务于多领域科研需求。; 适合人群:具备一定电力电子、自动控制或新能源背景的研究生、博士生及科研人员,熟悉MATLAB/Simulink环境,有志于复现高水平论文成果并开展创新研究。; 使用场景及目标:①复现光伏并网逆变器的阻抗建模与扫频分析过程,掌握其稳定性判据与仿真方法;②借鉴提供的丰富案例资源,支撑博士论文或期刊论文的仿真实验部分;③结合团队提供的算法与模型,快速搭建实验平台,提升科研效率。; 阅读建议:建议按文档目录顺序浏览,优先下载并运行配套仿真文件,结合理论学习与代码调试加深理解;重点关注锁相环与电流环的建模细节,同时可拓展学习其他复现案例以拓宽研究视野。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值