WebService的优缺点.docx
《WebService的优缺点.docx》由会员分享,可在线阅读,更多相关《WebService的优缺点.docx(14页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、WebService的优缺点Web service是一个平台的独立,低耦合的,自包含的、基于可编程的web的应用程序,可运用开放的XML(标准通用标记语言下的一个子集)标准来描述、发布、发觉、协调和配置这些应用程序,用于开发分布式的互操作的应用程序。1. 什么是WebService?对这个问题,我们至少有两种答案。从表面上看,WebService 就是一个应用程序,它向外界暴露出一个能够通过Web进行调用的API。这就是说,你能够用编程的方法通过Web来调用这个应用程序。我们把调用这个 WebService 的应用程序叫做客户。例如,你想创建一个WebService ,它的作用是返回当前的天气
2、状况。那么你可以建立一个ASP页面,它接受邮政编码作为查询字符串,然后返回一个由逗号隔开的字符串,包含了当前的气温柔天气。要调用这个ASP页面,客户端须要发送下面的这个HTTP GET恳求: 返回的数据就应当是这样:21,晴这个ASP页面就应当可以算作是WebService了。因为它基于HTTP GET恳求,暴露出了一个可以通过Web调用的API。当然WebService还有更多的东西。下面是对WebService更精确的说明:WebService是建立可互操作的分布式应用程序的新平台。作为一个Windows程序员,你可能已经用 COM或DCOM建立过基于组件的分布式应用程序。COM是一个特别
3、好的组件技术,但是我们也很简单举出COM并不能满意要求的状况。 WebService平台是一套标准,它定义了应用程序如何在Web上实现互操作性。你可以用任何你喜爱的语言,在任何你喜爱的平台上写 WebService ,只要我们可以通过WebService标准对这些服务进行查询和访问。2. WebService的优点:跨防火墙的通信假如应用程序有成千上万的用户,而且分布在世界各地,那么客户端和服务器之间的通信将是一个麻烦的问题。因为客户端和服务器之间通常会有防火墙或者代理服务器。在这种状况下,运用DCOM就不是那么简洁,通常也不便于把客户端程序发布到数量如此浩大的每一个用户手中。传统的做法是,选
4、择用阅读器作为客户端,写下一大堆ASP页面,把应用程序的中间层暴露给最终用户。这样做的结果是开发难度大,程序很难维护。举个例子,在应用程序里加入一个新页面,必需先建立好用户界面(Web页面),并在这个页面后面,包含相应商业逻辑的中间层组件,还要再建立至少一个 ASP页面,用来接受用户输入的信息,调用中间层组件,把结果格式化为HTML形式,最终还要把“结果页”送回阅读器。要是客户端代码不再如此依靠于 HTML表单,客户端的编程就简洁多了。假如中间层组件换成WebService的话,就可以从用户界面干脆调用中间层组件,从而省掉建立ASP页面的那一步。要调用 WebService,可以干脆运用Mic
5、rosoftSOAPToolkit或.NET这样的SOAP客户端,也可以运用自己开发的SOAP客户端,然后把它和应用程序连接起来。不仅缩短了开发周期,还削减了代码困难度,并能够增加应用程序的可维护性。同时,应用程序也不再须要在每次调用中间层组件时,都跳转到相应的“结果页”。从大多数人的阅历来看,在一个用户界面和中间层有较多交互的应用程序中,运用WebService这种结构,可以节约花在用户界面编程上20% 的开发时间。另外,这样一个由WebService组成的中间层,完全可以在应用程序集成或其它场合下重用。最终,通过WebService把应用程序的逻辑和数据“暴露”出来,还可以让其它平台上的客
6、户重用这些应用程序。应用程序集成企业级的应用程序开发者都知道,企业里常常都要把用不同语言写成的、在不同平台上运行的各种程序集成起来,而这种集成将花费很大的开发力气。应用程序常常须要从运行在IBM主机上的程序中获得数据;或者把数据发送到主机或UNIX应用程序中去。即使在同一个平台上,不同软件厂商生产的各种软件也经常须要集成起来。通过WebService,应用程序可以用标准的方法把功能和数据“暴露”出来,供其它应用程序运用。例如,有一个订单登录程序,用于登录从客户来的新订单,包括客户信息、发货地址、数量、价格和付款方式等内容;还有一个订单执行程序,用于实际货物发送的管理。这两个程序来自不同软件厂商
7、。一份新订单进来之后,订单登录程序须要通知订单执行程序发送货物。通过在订单执行程序上面增加一层 WebService,订单执行程序可以把“AddOrder”函数“暴露”出来。这样,每当有新订单到来时,订单登录程序就可以调用这个函数来发送货物了。B2B的集成用WebService集成应用程序,可以使公司内部的商务处理更加自动化。但当交易跨越供应商和客户、突破公司的界限时会怎么样呢?跨公司的商务交易集成通常叫做B2B集成。WebService是B2B集成胜利的关键。通过WebService,公司可以把关键的商务应用“暴露”给指定的供应商和客户。例如,把电子下单系统和电子发票系统“暴露”出来,客户就
8、可以以电子的方式发送订单,供应商则可以以电子的方式发送原料选购发票。当然,这并不是一个新的概念,EDI(电子文档交换)早就是这样了。但是,WebService的实现要比EDI简洁得多,而且WebService运行在Internet上,在世界任何地方都可轻易实现,其运行成本就相对较低。不过,WebService并不像EDI那样,是文档交换或B2B集成的完整解决方案。WebService只是 B2B集成的一个关键部分,还须要很多其它的部分才能实现集成。用WebService来实现B2B集成的最大好处在于可以轻易实现互操作性。只要把商务逻辑“暴露”出来,成为WebService,就可以让任何指定的合
9、作伙伴调用这些商务逻辑,而不管他们的系统在什么平台上运行,运用什么开发语言。这样就大大削减了花在B2B集成上的时间和成本,让很多原本无法承受EDI的中小企业也能实现B2B集成。软件和数据重用软件重用是一个很大的主题,重用的形式许多,重用的程度有大有小。最基本的形式是源代码模块或者类一级的重用,另一种形式是二进制形式的组件重用。3. WebService的缺点单机应用程序目前,企业和个人还运用着许多桌面应用程序。其中一些只须要与本机上的其它程序通信。在这种状况下,最好就不要用WebService,只要用本地的 API就可以了。COM特别适合于在这种状况下工作,因为它既小又快。运行在同一台服务器上
10、的服务器软件也是这样。最好干脆用COM或其它本地的API来进行应用程序间的调用。当然WebService也能用在这些场合,但那样不仅消耗太大,而且不会带来任何好处。局域网的同构应用程序在很多应用中,全部的程序都是用VB或VC开发的,都在Windows平台下运用COM,都运行在同一个局域网上。例如,有两个服务器应用程序须要相互通信,或者有一个Win32或WinForm的客户程序要连接局域网上另一个服务器的程序。在这些程序里,运用DCOM会比SOAP/HTTP有效得多。与此相类似,假如一个.NET程序要连接到局域网上的另一个.NET程序,应当运用.NETremoting。好玩的是,在.NETrem
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- WebService 优缺点
限制150内