> 文档中心 > WebService

WebService

WebService技术

  • WebService
    • WebService概念
    • WebService平台技术
      • XML:
      • SOAP(Simple Object Access Protocol简单对象访问协议):
      • WSDL:
    • WebService与Socket的区别

WebService

最近项目中碰到用WebService与上位进行通信的场景,于是在网上看了很多关于WebService的资料,接下来说一说我本人对WebService的理解。

WebService概念

WebService是一个跨编程语言和操作系统平台的远程调用技术,当一个系统由两个公司共同开发的时候经常会用到这种技术(A公司提供接口供B公司远程调用)

从表面上看,WebService就是一个应用程序向外界暴露出一个能通过Web进行调用的API,把调用这个WebService的应用程序叫做客户端,而把提供这个WebService的应用程序叫做服务端。从深层次看,WebService是建立可互操作的分布式应用程序的新平台,是一个平台,是一套标准。

WebService平台技术

XML+XSD,SOAPWSDL就是构成WebService平台的三大技术。

XML:

WebService采用HTTP协议传输数据,采用XML格式封装数据(即XML中说明调用远程服务对象的哪个方法,传递的参数是什么,以及服务对象的返回结果是什么)。XML是WebService平台中表示数据的格式。除了易于建立和易于分析外,XML主要的优点在于它既是平台无关的,又是厂商无关的。无关性是比技术优越性更重要的:软件厂商是不会选择一个由竞争对手所发明的技术的。

XML解决了数据表示的问题,但它没有定义一套标准的数据类型,更没有说怎么去扩展这套数据类型。例如,整形数到底代表什么?16位,32位,64位?这些细节对实现互操作性很重要。XML Schema(XSD)就是专门解决这个问题的一套标准。它定义了一套标准的数据类型,并给出了一种语言来扩展这套数据类型。WebService平台就是用XSD来作为其数据类型系统的。当你用某种语言(如VB.NET或C#)来构造一个Web service时,为了符合WebService标准,所有你使用的数据类型都必须被转换为XSD类型。你用的工具可能已经自动帮你完成了这个转换,但你很可能会根据你的需要修改一下转换过程。

SOAP(Simple Object Access Protocol简单对象访问协议):

WebService通过HTTP协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明HTTP消息的内容格式,这些特定的HTTP消息头和XML内容格式就是SOAP协议。SOAP提供了标准的RPC方法来调用Web Service。

SOAP协议 = HTTP协议 + XML数据格式

SOAP协议定义了SOAP消息的格式,SOAP协议是基于HTTP协议的,SOAP也是基于XML和XSD的,XML是SOAP的数据编码方式。

打个比喻:HTTP就是普通公路,XML就是中间的绿色隔离带和两边的防护栏,SOAP就是普通公路经过加隔离带和防护栏改造过的高速公路。

WSDL:

如下图所示
wsdl文件

WebService客户端要调用一个WebService服务,首先要有知道这个服务的地址在哪,以及这个服务里有什么方法可以调用,所以,WebService务器端首先要通过一个WSDL文件来说明自己家里有啥服务可以对外调用,服务是什么(服务中有哪些方法,方法接受的参数是什么,返回值是什么),服务的网络地址用哪个url地址表示,服务通过什么方式来调用。

WSDL(Web Services Description Language)就是这样一个基于XML的语言,用于描述Web Service及其函数、参数和返回值。它是WebService客户端和服务器端都能理解的标准格式。因为是基于XML的,所以WSDL既是机器可阅读的,又是人可阅读的,这将是一个很大的好处。一些最新的开发工具既能根据你的Web service生成WSDL文档,又能导入WSDL文档,生成调用相应WebService的代理类代码。

WSDL文件保存在Web服务器上,通过一个url地址就可以访问到它。客户端要调用一个WebService服务之前,要知道该服务的WSDL文件的地址。WebService服务提供商可以通过两种方式来暴露它的WSDL文件地址:1.注册到UDDI服务器,以便被人查找;2.直接告诉给客户端调用者。


上面对WebService做了简单介绍,接下来聊一聊WebService与常用的http、socket之间的区别。

WebService与Socket的区别

在说Socket之前我们先看一下网上关于socket的图片:
socket通信图
看了socket流程图之后我觉得socket与WebService没有什么区别,都是客户端和服务端的数据交互,但是在看了很多博客之后我觉得并不是这样。

  • socket是系统层面的东西,可以完成TCP,UDP等协议之间的通信。
  • WebSevice是应用层面的东西,是使用Socket + HTTP 协议 的一种规范。
  • socket 只是 java在网络层定义的类,用来实现网络层。上面的各层需要我们自己在程序里实现。
    socket位置

例如端口可以自己定义 、数据包的定义、 数据包的加密解密等

  • 而webService java实现了应用层的工具,他基于的服务为http协议,通过服务器才可以发布出去。 这样内部的端口的定义、数据包的定义和数据包的加密解密都做好了,所以我们就直接可以用了。

  • webService 内部数据格式为xml格式、由于基于http协议,所以可以不受防火墙的影响。 因为他的通信协议和我们浏览网页的协议是相同的。

总结:
因为WebService是建立在tcp/ip协议连接上,而socket是java实现tcp/ip的一种抽象技术,所以socket和WebService没有很亲密的关系,通俗点说WebService的底层是socker实现的。