REST服务是一种ROA(面向资源)的应用,主要特点就是把信息存在于HTTP协议方法中(GET,PUT),作用域存在于URI中。例如,在一个获取设备资源列表的GET请求中,作用域存在于URI中,方法信息是GET,作用域信息是URI中包含的对设备资源的过滤,分页,和排序条件。
传统的RPC风格:RFC请求都是HTTP协议的POST方法,其方法信息包含于SOAP协议包或HTTP协议包中,方法名称不具有通用性。其作用域角度来看,REST采用URI显示定义作用域,而RPC的这一信息同样包含于协议包中,不能直接呈现。
HTTP请求的安全性和幂等性:
安全性:外部系统对接口的访问,不会使服务器资源的状态发生改变。
幂等性(idempotence):指外部系统多同一个REST接口的多次访问,得到的资源状态是相同的。
GET(SELECT):从服务器取出资源(一项或多项)。有安全性和幂等性
POST(CREATE):在服务器新建一个资源。既不安全也不幂等
PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源)。不安全,但是幂等
PATCH(UPDATE):在服务器更新资源(客户端提供改变的属性)。 不安全,但是幂等
DELETE(DELETE):从服务器删除资源。 不安全,但是幂等
RESTFul在于把软件工程师从“操作”的泥淖中抽出来,使其更关注于“资源”,更一步说是“数据模型”。而关注于“数据模型”后的好处在于,能够帮助不同组件之间更好的解耦,消除依赖关系,以及增大系统拓展性。