Web Service那点事
出现
现在基于浏览器的客户端应用程序越来越流行,而从开发角度来看,一方面是客户端浏览器的安装配置不再需要我们再去花费很大的精力;另一方林则是因为客户端和服务器之间通信的问题。
传统的Windows客户应用程序使用DCOM来与服务器进行通信和调用远程对象。而使用DCOM却来完成通信是个特别繁琐和麻烦的工作,特别的不方便,在此情况下,http协议完美的解决了客户端与服务器之间的通信问题,这是因为任务运行的web浏览器都在使用http协议,同时当前许多防火墙也配置为只允许HTTP连接。
应用程序除了通信这个问题之外,还有一个特别严峻的问题,那就是异构系统的互操作。如果所有应用程序都是同一种平台或语言就不会出现这个问题了,但事实却不是这样,有用COM或.NET语言写的还有使用C++、Java、VisualBasic和其他各种各样的语言编写的应用程序,所有这些不同语言编写的应用程序如果之间需要集成并进行数据交互,方式多种多样,各不相同。没有一个统一的应用程序通信标准,是独立与平台、语言的。
所以WebService应运而生,通过Web Service客户端和服务器可以自由的用HTTP进行通信,不论两个程序的平台和编程语言是什么。
是什么
从小的说,Web Service就是一个技术,它向外界暴露出一个能够通过Web进行调用的api,我们可以直接调用这个Web Service的api进行开发。
从大的说,WebService是一个平台,这个平台可以用来建立可以互操作的分布式应用程序。所以WebService平台就是一套标准,这个标准它定义了应用程序如何在Web上实现互操作性。你可以用任何你喜欢的语言,在任何你喜欢的平台上写Web service,只要我们可以通过Web service标准对这些服务进行查询和访问。
一句话总结WebService定义,Web Service是一种跨越编程语言和跨越操作系统平台的远程调用技术。
平台技术
XML+XSD,SOAP和WSDL就是构成WebService平台的三大技术。
XML+XSD:
WebService采用HTTP协议传输数据,采用XML格式封装数据(即XML中说明调用远程服务对象的哪个方法,传递的参数是什么,以及服务对象的返回结果是什么)。XML是WebService平台中表示数据的格式。除了易于建立和易于分析外,XML主要的优点在于它既是平台无关的,又是厂商无关的。无关性是比技术优越性更重要的:软件厂商是不会选择一个由竞争对手所发明的技术的。
XML解决了数据表示的问题,但它没有定义一套标准的数据类型,更没有说怎么去扩展这套数据类型。例如,整形数到底代表什么?16位,32位,64位?这些细节对实现互操作性很重要。XMLSchema(XSD)就是专门解决这个问题的一套标准。它定义了一套标准的数据类型,并给出了一种语言来扩展这套数据类型。WebService平台就是用XSD来作为其数据类型系统的。当你用某种语言(如VB.NET或C#)来构造一个Webservice时,为了符合WebService标准,所有你使用的数据类型都必须被转换为XSD类型。你用的工具可能已经自动帮你完成了这个转换,但你很可能会根据你的需要修改一下转换过程。
SOAP:
WebService通过HTTP协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明HTTP消息的内容格式,这些特定的HTTP消息头和XML内容格式就是SOAP协议。SOAP提供了标准的RPC方法来调用WebService。
SOAP协议 = HTTP协议 + XML数据格式
SOAP协议定义了SOAP消息的格式,SOAP协议是基于HTTP协议的,SOAP也是基于XML和XSD的,XML是SOAP的数据编码方式。打个比喻:HTTP就是普通公路,XML就是中间的绿色隔离带和两边的防护栏,SOAP就是普通公路经过加隔离带和防护栏改造过的高速公路。
WSDL:
好比我们去商店买东西,首先要知道商店里有什么东西可买,然后再来购买,商家的做法就是张贴广告海报。WebService也一样,WebService客户端要调用一个WebService服务,首先要有知道这个服务的地址在哪,以及这个服务里有什么方法可以调用,所以,WebService务器端首先要通过一个WSDL文件来说明自己家里有啥服务可以对外调用,服务是什么(服务中有哪些方法,方法接受的参数是什么,返回值是什么),服务的网络地址用哪个url地址表示,服务通过什么方式来调用。
WSDL(Web Services DescriptionLanguage)就是这样一个基于XML的语言,用于描述WebService及其函数、参数和返回值。它是WebService客户端和服务器端都能理解的标准格式。因为是基于XML的,所以WSDL既是机器可阅读的,又是人可阅读的,这将是一个很大的好处。一些最新的开发工具既能根据你的Webservice生成WSDL文档,又能导入WSDL文档,生成调用相应WebService的代理类代码。
WSDL文件保存在Web服务器上,通过一个url地址就可以访问到它。客户端要调用一个WebService服务之前,要知道该服务的WSDL文件的地址。WebService服务提供商可以通过两种方式来暴露它的WSDL文件地址:1.注册到UDDI服务器,以便被人查找;2.直接告诉给客户端调用者。
应用场景
WebService的http通信和跨平台决定了它的应用场景。
前面提到当前许多防火墙也配置为只允许HTTP连接,所以WebService使用于跨防火墙通信;
WebService跨语言的特性使它在异构系统的集成方面,有独特的优势,所以用它将不同语言不同操作系统的应用程序进行集成;
Web Service将商业逻辑做到互操作,只要把商务逻辑“暴露”出来,成为WebService,就可以让任何指定的合作伙伴调用这些商务逻辑,而不管他们的系统在什么平台上运行,使用什么开发语言,这一块现在在B2B集成上特别广泛。跨公司的商务交易集成通常叫做B2B集成,通过WebService实现逻辑业务的互操作,这样就大大减少了花在B2B集成上的时间和成本,让许多原本无法承受EDI的中小企业也能实现B2B集成;
这一点和上面一点其实本质是一样的,都利用了WebService的互操作性,采用WebService应用程序可以用标准的方法把功能和数据“暴露”出来,供其它应用程序使用,达到业务级重用。
最后
本篇文章主要介绍了WebService为了解决什么问题而出现,同时介绍了Web Service的定义、核心技术最后介绍了Web Service的使用场景,关于WebService的学习才刚刚开始,有不对的请大家多多指正。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。