restful是什么
本质:一种软件架构风格
核心:面向资源
解决的问题:降低开发的复杂性、提高系统的可伸缩性
设计概念和准则:网络上的所有事物都可以被抽象为资源,每一个资源都有唯一的资源标识,对资源的操作不会改变这些标识。所有的操作都是无状态的。
什么是资源:所谓资源,就是网络上的一个实体或者一段信息。
http协议的一种实现。RFC 应用层 ,特点是简洁,快速
http:schema://host[:port]/path[?query-string][#anchor]
schema: 指定底层使用的协议(https、http、ftp)
host: 服务器的ip地址或者域名
port: 80 443
path: 访问资源的路径
query-string: 发送给服务器的数据
anchor: 锚
http请求:
请求行:method Request-URI HTTP-version CRLF
消息报头,请求正文
GET /HTTP/1.1 CRLF
GET POST HEAD PUT DELETE OPTIONS
http响应:
状态行,消息报头,响应正文
200 400 401 404 500 503
SOAP WEBSERVICE 安全证高
效率和易用性
restful 安全性不足 速度快
资源路径(URI)
在RESTFUL架构中,每个网址代表一种资源,所以网址中不能有动词,只能有名词。一般来说API中的名词应该使用复数。
举个例子:有一个API提供动物园的信息,还包括各种动物和雇员的信息。则他的路径应该设置成下面这样。
https://api.example.com/v1/zoos //动物园资源
https://api.example.com/v1/animals //动物资源
https://api.example.com/v1/employees //动物园资源
HTTP动词
对于资源的操作(CURD),由HTTP动词(谓词)表示。
GET POST PUT DELETE
post /zoos
get /zoos/ID
put /zoos/ID
delete /zoos/ID
过滤信息
?offset=10:指定返回记录的开始位置
?page=2&per_page=100:指定第几页,以及每页的记录数
?sortby=name&order=asc:指定返回结果排序,以及排序顺序。
?animal_type_id=1:指定筛选条件
状态码
服务器向用户返回的状态码和提示信息,使用标准HTTP状态码。
错误处理
如果状态码为4XX或者5XX
{"error":"错误信息"}
返回结果
GET /collections: 返回资源对象的列表(数组)
GET /collections/identity:返回单个资源对象
POST /collections:返回新生成的资源对象
PUT /collections/identity:返回完整的资源对象
PATCH /collections/identity:返回被修改的属性
DELETE /collections/identity:返回一个空文档