原文引自:http://blog.csdn.net/wooshn/article/details/8069087java
WebService究竟是什么?web
一言以蔽之:WebService是一种跨编程语言和跨操做系统平台的远程调用技术。编程
所谓跨编程语言和跨操做平台,就是说服务端程序采用java编写,客户端程序则能够采用其余编程语言编写,反之亦然!跨操做系统平台则是指服务端程序和客户端程序能够在不一样的操做系统上运行。浏览器
所谓远程调用,就是一台计算机a上的一个程序能够调用到另一台计算机b上的一个对象的方法,譬如,银联提供给商场的pos刷卡系统,商场的POS机转帐调用的转帐方法的代码实际上是跑在银行服务器上。再好比,amazon,天气预报系统,淘宝网,校内网,百度等把本身的系统服务以webservice服务的形式暴露出来,让第三方网站和程序能够调用这些服务功能,这样扩展了本身系统的市场占有率,往大的概念上吹,就是所谓的SOA应用。服务器
其实能够从多个角度来理解WebService,从表面上看,WebService就是一个应用程序向外界暴露出一个能经过Web进行调用的API,也就是说能用编程的方法经过Web来调用这个应用程序。咱们把调用这个WebService的应用程序叫作客户端,而把提供这个WebService的应用程序叫作服务端。从深层次看,WebService是创建可互操做的分布式应用程序的新平台,是一个平台,是一套标准。它定义了应用程序如何在Web上实现互操做性,你能够用任何你喜欢的语言,在任何你喜欢的平台上写Web service ,只要咱们能够经过Web service标准对这些服务进行查询和访问。 网络
WebService平台须要一套协议来实现分布式应用程序的建立。任何平台都有它的数据表示方法和类型系统。要实现互操做性,WebService平台必须提供一套标准的类型系统,用于沟通不一样平台、编程语言和组件模型中的不一样类型系统。Web service平台必须提供一种标准来描述Web service,让客户能够获得足够的信息来调用这个Web service。最后,咱们还必须有一种方法来对这个Web service进行远程调用,这种方法实际是一种远程过程调用协议(RPC)。为了达到互操做性,这种RPC协议还必须与平台和编程语言无关。框架
3、WebService平台技术编程语言
XML+XSD,SOAP和WSDL就是构成WebService平台的三大技术。分布式
XML+XSD:函数
WebService采用HTTP协议传输数据,采用XML格式封装数据(即XML中说明调用远程服务对象的哪一个方法,传递的参数是什么,以及服务对象的返回结果是什么)。XML是WebService平台中表示数据的格式。除了易于创建和易于分析外,XML主要的优势在于它既是平台无关的,又是厂商无关的。无关性是比技术优越性更重要的:软件厂商是不会选择一个由竞争对手所发明的技术的。
XML解决了数据表示的问题,但它没有定义一套标准的数据类型,更没有说怎么去扩展这套数据类型。例如,整形数到底表明什么?16位,32位,64位?这些细节对实现互操做性很重要。XML Schema(XSD)就是专门解决这个问题的一套标准。它定义了一套标准的数据类型,并给出了一种语言来扩展这套数据类型。WebService平台就是用XSD来做为其数据类型系统的。当你用某种语言(如VB.NET或C#)来构造一个Web service时,为了符合WebService标准,全部你使用的数据类型都必须被转换为XSD类型。你用的工具可能已经自动帮你完成了这个转换,但你极可能会根据你的须要修改一下转换过程。
SOAP:
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:
比如咱们去商店买东西,首先要知道商店里有什么东西可买,而后再来购买,商家的作法就是张贴广告海报。 WebService也同样,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.直接告诉给客户端调用者。
4、WebService开发
WebService开发能够分为服务器端开发和客户端开发两个方面:
服务端开发:把公司内部系统的业务方法发布成WebService服务,供远程合做单位和我的调用。(借助一些WebService框 架能够很轻松地把本身的业务对象发布成WebService服务,Java方面的典型WebService框架包括:axis,xfire,cxf等,java ee服务器一般也支持发布WebService服务,例如JBoss。)
客户端开发:调用别人发布的WebService服务,大多数人从事的开发都属于这个方面,例如,调用天气预报WebService服务。(使用厂商的WSDL2Java之类的工具生成静态调用的代理类代码;使用厂商提供的客户端编程API类;使用SUN公司早期标准的jax-rpc开发包;使用SUN公司最新标准的jax-ws开发包。固然SUN已被ORACLE收购)
WebService的工做调用原理:对客户端而言,咱们给这各种WebService客户端API传递wsdl文件的url地址,这些API就会建立出底层的代理类,我调用这些代理,就能够访问到webservice服务。代理类把客户端的方法调用变成soap格式的请求数据再经过HTTP协议发出去,并把接收到的soap数据变成返回值返回。对服务端而言,各种WebService框架的本质就是一个大大的Servlet,当远程调用客户端给它经过http协议发送过来soap格式的请求数据时,它分析这个数据,就知道要调用哪一个java类的哪一个方法,因而去查找或建立这个对象,并调用其方法,再把方法返回的结果包装成soap格式的数据,经过http响应消息回给客户端。
5、适用场合
一、跨防火墙通讯:
若是应用程序有成千上万的用户,并且分布在世界各地,那么客户端和服务器之间的通讯将是一个棘手的问题。由于客户端和服务器之间一般会有防火墙或者代理服务器。在这种状况下,使用DCOM就不是那么简单,一般也不便于把客户端程序发布到数量如此庞大的每个用户手中。传统的作法是,选择用浏览器做为客户端,写下一大堆ASP页面,把应用程序的中间层暴露给最终用户。这样作的结果是开发难度大,程序很难维护。若是中间层组件换成WebService的话,就能够从用户界面直接调用中间层组件。从大多数人的经验来看,在一个用户界面和中间层有较多交互的应用程序中,使用WebService这种结构,能够节省花在用户界面编程上20%的开发时间。
二、应用程序集成:
企业级的应用程序开发者都知道,企业里常常都要把用不一样语言写成的、在不一样平台上运行的各类程序集成起来,而这种集成将花费很大的开发力量。应用程序常常须要从运行在IBM主机上的程序中获取数据;或者把数据发送到主机或UNIX应用程序中去。即便在同一个平台上,不一样软件厂商生产的各类软件也经常须要集成起来。经过WebService,能够很容易的集成不一样结构的应用程序。
三、B2B集成:
用WebService集成应用程序,可使公司内部的商务处理更加自动化。但当交易跨越供应商和客户、突破公司的界限时会怎么样呢?跨公司的商务交易集成一般叫作B2B集成。WebService是B2B集成成功的关键。经过WebService,公司能够把关键的商务应用“暴露”给指定的供应商和客户。例如,把电子下单系统和电子发票系统“暴露”出来,客户就能够以电子的方式发送订单,供应商则能够以电子的方式发送原料采购发票。固然,这并非一个新的概念,EDI(电子文档交换)早就是这样了。可是,WebService的实现要比EDI简单得多,并且WebService运行在Internet上,在世界任何地方均可轻易实现,其运行成本就相对较低。不过,WebService并不像EDI那样,是文档交换或B2B集成的完整解决方案。WebService只是B2B集成的一个关键部分,还须要许多其它的部分才能实现集成。
用WebService来实现B2B集成的最大好处在于能够轻易实现互操做性。只要把商务逻辑“暴露”出来,成为WebService,就可让任何指定的合做伙伴调用这些商务逻辑,而无论他们的系统在什么平台上运行,使用什么开发语言。这样就大大减小了花在B2B集成上的时间和成本,让许多本来没法承受EDI的中小企业也能实现B2B集成。