> 文章列表 > 【RestFul系列】RestFul学习笔记

【RestFul系列】RestFul学习笔记

【RestFul系列】RestFul学习笔记

目录

一、REST定义

二、REST架构的主要原则

三、RESTful介绍

1、资源(Resources)

2、 表现层(Representation)

3、 状态转化(State Transfer)

四、RESTful的使用

1、RESTful资源操作

2、接口示例:

     2.1.传统URL请求格式

     2.2.RESTful请求格式:

3、响应设计

​4、http响应状态码

五、结语


一、REST定义

REST 是Roy Fielding博士在2000年他的博士论文中提出来的。它是一种针对网络应用的设计和开发方式,可以降低开发的复杂性,提高系统的可伸缩性。REST(Representational State Transfer)表象化状态转变(表述性状态转变),基于HTTP、URI、XML、JSON等标准和协议,支持轻量级、跨平台、跨语言的架构设计。是Web服务的一种新的架构风格(一种思想)。

二、REST架构的主要原则

  • 对网络上所有的资源都有一个资源标志符。

  • 对资源的操作不会改变标识符。

  • 同一资源有多种表现形式(xml、json)

  • 所有操作都是无状态的(Stateless)

三、RESTful介绍

简单的说:RESTful是一种架构的规范与约束、原则,符合这种规范的架构就是RESTful架构。

1、资源(Resources)

REST的名称"表现层状态转化"中,省略了主语。“表现层"其实指的是"资源”(Resources)的"表现层"

所谓"资源",就是网络上的一个实体,或者说是网络上的一个具体信息。它可以是一段文本、一张图片、一首歌曲、一种服务,总之就是一个具体的实在。你可以用一个 URI(统一资源定位符)指向它,每种资源对应一个特定的URI。要获取这个资源,访问它的URI就可以,因此URI就成了每一个资源的地址或独一无二的识别符

所谓"上网",就是与互联网上一系列的"资源"互动,调用它的URL

2、 表现层(Representation)

“资源"是一种信息实体,它可以有多种外在表现形式。我们把"资源"具体呈现出来的形式,叫做它的"表现层”(Representation)

比如,文本可以用txt格式表现,也可以用HTML格式、XML格式、JSON格式表现,甚至可以采用二进制格式;图片可以用JPG格式表现,也可以用PNG格式表现

URI只代表资源的实体,不代表它的形式。严格地说,有些网址最后的".html"后缀名是不 必要的,因为这个后缀名表示格式,属于"表现层"范畴,而URI应该只代表"资源"的位置。它的具体表现形式,应该在HTTP请求的头信息中用Accept和Content-Type字段指定,这两个字段才是对"表现层"的描述

3、 状态转化(State Transfer)

访问一个网站,就代表了客户端和服务器的一个互动过程。在这个过程中,势必涉及到数据和状态的变化

互联网通信协议HTTP协议,是一个无状态协议。这意味着,所有的状态都保存在服务器端。因此,如果客户端想要操作服务器,必须通过某种手段,让服务器端发生"状态转化"(State Transfer)。而这种转化是建立在表现层之上的,所以就是"表现层状态转化"

客户端用到的手段,只能是HTTP协议。具体来说,就是HTTP协议里面,四个表示操作方式的动词:GET、POST、PUT、DELETE。

它们分别对应四种基本操作:

GET用来获取资源
POST用来新建资源(也可以用于更新资源)
PUT用来更新资源
DELETE用来删 除资源
综合上面的解释,我们总结一下什么是RESTful架构:

每一个URI代表一种资源
客户端和服务器之间,传递这种资源的某种表现层
客户端通过四个HTTP动词,对服务器端资源进行操作,实现 “表现层状态转化”

四、RESTful的使用

1、RESTful资源操作

幂等性:对同一REST接口的多次访问,得到的资源状态是相同的。

安全性:对该REST接口访问,不会使服务器端资源的状态发生改变。

2、接口示例:

2.1.传统URL请求格式:

http://localhost:8080/user/query/1 GET 根据用户id查询用户数据

http://ocalhost:8080/user/save POST 新增用户

http://ocalhost:8080/user/update POST 修改用户信息

http://ocalhost:8080/user/delete GET/POST 删除用户信息

2.2.RESTful请求格式:

http://localhost:8080/user/1 GET 根据用户id查询用户数据

http://localhost:8080/user POST 新增用户

http://localhost:8080/user PUT 修改用户信息

http://localhost:8080/user DELETE 删除用户信息

3、响应设计

原则:数据接收到即可使用,无需拆箱。

在一次请求中,content body仅仅用于传输数据。Header中存放描述请求或请求的元数据,例如 X-Result-Fields。

这里写图片描述

4、http响应状态码

 根据http响应码,判断请求状态,进而做出提醒。

这里写图片描述

 

五、结语

RESTful减少了传统请求的拆装箱操作,结构清晰,在接口定义中受到前后端开发者的青睐。因此,近几年在很多互联网科技公司使用的越来越多。