REST 和 SOAP、RPC 有什么区别?

来源:互联网 发布:bi 数据统计是什么 编辑:程序博客网 时间:2024/05/23 21:42

REST 和 SOAP、RPC 有什么区别?

leajone 2017-08-28 18:15

第一个问题:

什么是RESTful?

REST这个词,是Roy Thomas Fielding在他2000年的博士论文中提出的。那RESTful到底是什么呢?简单的讲,它是:

一种架构设计风格,提供了设计原则和约束条件,而不是架构。而满足这些约束条件和原则的应用程序或设计就是 RESTful架构或服务。

第二个问题:

到底 REST 和 SOAP、RPC 有何区别?

这个问题比较大,要知道他们有什么区别首先需要明白,他们分别是什么?

REST

上面已经简单的说明了它是什么。

SOAP

(简单对象访问协议)是什么?

SOAP是一种数据交换协议规范,是一种轻量的、简单的、基于XML的协议的规范。它有什么优点?简单总结为:

易用,灵活,跨语言,跨平台。

易用:是因为它的消息是基于xml,并封装成了符合http协议,因此,它符合任何路由器、 防火墙或代理服务器的要求。

灵活:表现在极具拓展性,SOAP 无需中断已有的应用程序, SOAP 客户端、 服务器和协议自身都能发展。而且SOAP 能极好地支持中间介质和层次化的体系结构。

跨语言:soap可以使用任何语言来完成,只要发送正确的soap请求即可。

跨平台:基于soap的服务可以在任何平台无需修改即可正常使用。

RPC(远程过程调用)是什么?

简单的说,RPC就是从一台机器(客户端)上通过参数传递的方式调用另一台机器(服务器)上的一个函数或方法(可以统称为服务)并得到返回的结果。

RPC 会隐藏底层的通讯细节(不需要直接处理Socket通讯或Http通讯)

RPC 是一个请求响应模型。客户端发起请求,服务器返回响应(类似于Http的工作方式)

RPC 在使用形式上像调用本地函数(或方法)一样去调用远程的函数(或方法)。

二者各有自己的使用场景。如果创建的分布式服务要求较好的安全性,对于传输等底层实现要求较强的可定制性,可以考虑SOAP;如果要求设计实现简单,一般来说安全性要求不高可以考虑REST。这只是一般情况,但偏于面向资源的服务使用REST有天然的优势

从上面我们可以看出,

REST 和 SOAP、RPC 有何区别呢?没什么太大区别,他们的本质都是提供可支持分布式的基础服务,最大的区别在于他们各自的的特点所带来的不同应用场景。

REST

可以看着是http协议的一种直接应用,默认基于json作为传输格式,使用简单,学习成本低效率高,~~但是安全性较低~~,而SOAP可以看着是一个重量级的协议,基于xml,SOAP在安全方面是通过使用XML-Security和XML-Signature两个规范组成了WS-Security来实现安全控制的,当前已经得到了各个厂商的支持,.net ,php ,java 都已经对其有了很好的支持 。这是REST薄弱的地方。

FAQ:

webservice 是RPC的一种实现吗?

RPC(Remote Process Call)是远程进程调用,无论你通过HTTP协议也好,还是Socket(套接字)协议也罢,能够调用远程规定好的接口就可称之为RPC。

WebService可以理解为实现RPC的一种方式,传输数据格式为XML。