RESTful架构风格

RESTful

CSDN地址:https://blog.csdn.net/weixin_45921593/article/details/122421374
image-20220110224549090

概念

RESTful(Representational State Transfer),即表现层状态转化。它是一种Web应用程序的设计风格和开发方式,其基于HTTP。适用于现代互联网厂商作为业务接口的场景,动作类型为新增、变更、删除所调用资源。

说人话:URL定位资源,使用HTTP动词(GET、POST、DELETE、PUT)描索操作。

如果一个架构符合REST原则,就称它为RESTful架构。

如何使用

  • GET:获取资源;
  • POST:新建资源;
  • PUT:更新资源;
  • DELETE:删除资源;

**注意:RESTful风格种URI不能包含动词。**因为“资源”表示一种实体,所以应该时名词,URI不应该有动词,动词应该放在HTTP协议中。

举例来说,某个URI是/posts/show/1,其中show是动词,这个URI就设计错了,正确的写法应该是/posts/1,然后用GET方法表示show。

如果某些动作是HTTP动词表示不了的,你就应该把动作做成一种资源。比如网上汇款,从账户1向账户2汇款500元,错误的URI是:

POST /accounts/1/transfer/500/to/2

正确的写法是把动词transfer改成名词transaction,资源不能是动词,但是可以是一种服务:

POST /transaction HTTP/1.1
Host: 127.0.0.1
  
from=1&to=2&amount=500.00

另一个设计误区,就是在URI中加入版本号

http://www.example.com/app/1.0/foo

http://www.example.com/app/1.1/foo

http://www.example.com/app/2.0/foo

因为不同的版本,可以理解成同一种资源的不同表现形式,所以应该采用同一个URI。版本号可以在HTTP请求头信息的Accept字段中进行区分(参见Versioning REST Services):

Accept: vnd.example-com.foo+json; version=1.0

Accept: vnd.example-com.foo+json; version=1.1

Accept: vnd.example-com.foo+json; version=2.0

为什么要使用RESTful风格?

RESTful风格结构清晰、符合标准、易于理解、拓展方便等。

“古代”网页时前端后端融在一起的,比如之前的PHP、JSP等。在之前的桌面时代问题大,但是近年来移动互联网的发展,各种类型的Client层出不穷,RESTful可以通过一套统一的接口为Web、iOS和Android提供服务。另外对于广大平台来说,比如微博开放平台、微信公众平台等,它们不需要显式的前端,只需要一套提供服务的接口,于是RESTful更是它们最好的选择。如图所示:

image-20220110224549090

缺点

  • RESTful不是一种规范,而是一种风格,它不具有强制性;
  • 抽象资源。所谓的抽象资源是“不直接对应数据库表的资源”。比如“登录/登出”。如果你用RPC式的接口设计,这就很直接:POST /loginPOST /logout。但是你要硬套RESTful,你就得挖空心思的想出一个抽象资源“会话”(session)。登录 = 创建会话,登出 = 销毁会话。于是你把接口设计成 POST /sessionsDELETE /sessions。这就很反直觉,且背离RESTful的设计初衷。
  • 参数农户分散到路径、query、body三个地方,设计复杂,用户使用起来不方便,不如全放body;

RPC的API

另一种选择是:设计API也可以使用RPC式的API,且一律POST /命名空间/资源类型/动作。参数全都带在body里。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值