`

WebService技术架构

阅读更多

WebService技术架构
当前,WebService是一个热门话题。但是,WebService究竟是什么?什么情况下应该用WebService?什么情况下不应该用WebService?是需要我们正确认识的。
    今天,在课堂上,老师为我们讲述了WebService技术的常见应用,使我们认识到了WebService技术的特点及应用场合。
1. 什么是WebService?
  <1> 对这个问题,我们至少有两种答案。从表面上看,WebService 就是一个应用程序,它向外界暴露出一个能够通过Web进行调用的API。这就是说,你能够用编程的方法通过Web来调用这个应用程序。我们把调用这个 WebService 的应用程序叫做客户。
    例如,你想创建一个WebService ,它的作用是返回当前的天气情况。那么你可以建立一个ASP页面,它接受邮政编码作为查询字符串,然后返回一个由逗号隔开的字符串,包含了当前的气温和天气。要调用这个ASP页面,客户端需要发送下面的这个HTTP GET请求:http://host.company.com/weather.asp?zipcode=20171 返回的数据就应该是这样:
    21,晴
    这个ASP页面就应该可以算作是WebService了。因为它基于HTTP GET请求,暴露出了一个可以通过Web调用的API。当然WebService还有更多的东西。
  <2> 下面是对WebService更精确的解释:WebService是建立可互操作的分布式应用程序的新平台。作为一个Windows程序员,你可能已经用 COM或DCOM建立过基于组件的分布式应用程序。COM是一个非常好的组件技术,但是我们也很容易举出COM并不能满足要求的情况。 WebService平台是一套标准,它定义了应用程序如何在Web上实现互操作性。你可以用任何你喜欢的语言,在任何你喜欢的平台上写 WebService ,只要我们可以通过WebService标准对这些服务进行查询和访问。


2. WebService的优点:
<1> 跨防火墙的通信
    如果应用程序有成千上万的用户,而且分布在世界各地,那么客户端和服务器之间的通信将是一个棘手的问题。因为客户端和服务器之间通常会有防火墙或者代理服务器。在这种情况下,使用DCOM就不是那么简单,通常也不便于把客户端程序发布到数量如此庞大的每一个用户手中。传统的做法是,选择用浏览器作为客户端,写下一大堆ASP页面,把应用程序的中间层暴露给最终用户。这样做的结果是开发难度大,程序很难维护。
    举个例子,在应用程序里加入一个新页面,必须先建立好用户界面(Web页面),并在这个页面后面,包含相应商业逻辑的中间层组件,还要再建立至少一个 ASP页面,用来接受用户输入的信息,调用中间层组件,把结果格式化为HTML形式,最后还要把“结果页”送回浏览器。要是客户端代码不再如此依赖于 HTML表单,客户端的编程就简单多了。
  如果中间层组件换成WebService的话,就可以从用户界面直接调用中间层组件,从而省掉建立ASP页面的那一步。要调用WebService,可以直接使用MicrosoftSOAPToolkit或.NET这样的SOAP客户端,也可以使用自己开发的SOAP客户端,然后把它和应用程序连接起来。不仅缩短了开发周期,还减少了代码复杂度,并能够增强应用程序的可维护性。同时,应用程序也不再需要在每次调用中间层组件时,都跳转到相应的“结果页”。
  从大多数人的经验来看,在一个用户界面和中间层有较多交互的应用程序中,使用WebService这种结构,可以节省花在用户界面编程上20%的开发时间。另外,这样一个由WebService组成的中间层,完全可以在应用程序集成或其它场合下重用。最后,通过WebService把应用程序的逻辑和数据“暴露”出来,还可以让其它平台上的客户重用这些应用程序。
<2> 应用程序集成
    企业级的应用程序开发者都知道,企业里经常都要把用不同语言写成的、在不同平台上运行的各种程序集成起来,而这种集成将花费很大的开发力量。应用程序经常需要从运行在IBM主机上的程序中获取数据;或者把数据发送到主机或UNIX应用程序中去。即使在同一个平台上,不同软件厂商生产的各种软件也常常需要集成起来。通过WebService,应用程序可以用标准的方法把功能和数据“暴露”出来,供其它应用程序使用。
  例如,有一个订单登录程序,用于登录从客户来的新订单,包括客户信息、发货地址、数量、价格和付款方式等内容;还有一个订单执行程序,用于实际货物发送的管理。这两个程序来自不同软件厂商。一份新订单进来之后,订单登录程序需要通知订单执行程序发送货物。通过在订单执行程序上面增加一层 WebService,订单执行程序可以把“AddOrder”函数“暴露”出来。这样,每当有新订单到来时,订单登录程序就可以调用这个函数来发送货物了。
<3> B2B的集成
  用WebService集成应用程序,可以使公司内部的商务处理更加自动化。但当交易跨越供应商和客户、突破公司的界限时会怎么样呢?跨公司的商务交易集成通常叫做B2B集成。
  WebService是B2B集成成功的关键。通过WebService,公司可以把关键的商务应用“暴露”给指定的供应商和客户。例如,把电子下单系统和电子发票系统“暴露”出来,客户就可以以电子的方式发送订单,供应商则可以以电子的方式发送原料采购发票。当然,这并不是一个新的概念,EDI(电子文档交换)早就是这样了。但是,WebService的实现要比EDI简单得多,而且WebService运行在Internet上,在世界任何地方都可轻易实现,其运行成本就相对较低。不过,WebService并不像EDI那样,是文档交换或B2B集成的完整解决方案。WebService只是 B2B集成的一个关键部分,还需要许多其它的部分才能实现集成。
  用WebService来实现B2B集成的最大好处在于可以轻易实现互操作性。只要把商务逻辑“暴露”出来,成为WebService,就可以让任何指定的合作伙伴调用这些商务逻辑,而不管他们的系统在什么平台上运行,使用什么开发语言。这样就大大减少了花在B2B集成上的时间和成本,让许多原本无法承受EDI的中小企业也能实现B2B集成。
<4> 软件和数据重用
  软件重用是一个很大的主题,重用的形式很多,重用的程度有大有小。最基本的形式是源代码模块或者类一级的重用,另一种形式是二进制形式的组件重用。
3. WebService的缺点
<1> 单机应用程序
  目前,企业和个人还使用着很多桌面应用程序。其中一些只需要与本机上的其它程序通信。在这种情况下,最好就不要用WebService,只要用本地的 API就可以了。COM非常适合于在这种情况下工作,因为它既小又快。运行在同一台服务器上的服务器软件也是这样。最好直接用COM或其它本地的API来进行应用程序间的调用。当然WebService也能用在这些场合,但那样不仅消耗太大,而且不会带来任何好处。
<2> 局域网的同构应用程序
  在许多应用中,所有的程序都是用VB或VC开发的,都在Windows平台下使用COM,都运行在同一个局域网上。例如,有两个服务器应用程序需要相互通信,或者有一个Win32或WinForm的客户程序要连接局域网上另一个服务器的程序。在这些程序里,使用DCOM会比SOAP/HTTP有效得多。与此相类似,如果一个.NET程序要连接到局域网上的另一个.NET程序,应该使用.NETremoting。有趣的是,在.NETremoting 中,也可以指定使用SOAP/HTTP来进行WebService调用。不过最好还是直接通过TCP进行RPC调用,那样会有效得多。

分享到:
评论

相关推荐

    【京华志】webservice技术架构

    三、WebService技术架构的关键组件 1. **SOAP引擎**:负责处理SOAP消息的发送和接收,解析消息内容并调用相应的服务方法。 2. **服务代理/客户端库**:为开发者提供简便的API,用于生成SOAP消息、解析响应,以及与...

    webservice技术架构

    Web Services技术架构是一种用于构建分布式系统的技术,它允许不同的应用程序和服务之间进行通信和交互,不受平台、编程语言或地理位置的限制。Web Services的核心优势在于其跨平台、跨语言的互操作性和灵活性,使得...

    基于WebService 的智能家居系统研究

    WebService技术架构可概括为一个堆栈模型,包括传输层(HTTP)、消息层(SOAP)、描述层(WSDL)、业务层(UDDI)等。 三、以太网作为智能家居通信网络 随着技术的发展,以太网因其良好的数据传输能力逐渐成为智能...

    基于WebService多层架构MIS系统的应用研究

    基于WebService多层架构MIS系统的应用研究,引入web service技术,并借鉴MIS系统分层开发思想,提出一种基于webservice多层架构MIS系统应用方案

    WebService技术及其应用实例论文

    本文主要介绍了WebService技术和WebService技术在实际应用中的一个例子。WebService技术是通过构筑一个通用的、与平台和语言无关的技术层,使得各种不同平台上的应用系统间,实施彼此的连接和集成。本文首先对...

    Struts+Spring+Hibernate+WebService集成架构.doc

    在现代软件开发领域,尤其在企业级应用开发中,采用模块化、层次化的架构模式已经成为一种趋势,其中Struts、Spring、Hibernate及WebService技术组合的集成架构备受青睐。这种集成架构能够有效地分离业务逻辑、数据...

    Struts+Spring+Hibernate+WebService集成架构

    Struts+Spring+Hibernate+WebService集成架构是一种常见的企业级应用开发模式,用于构建高效、可扩展的Web应用程序。这个架构组合充分利用了各个框架的优势,提供了一种强大的模型-视图-控制器(MVC)设计模式的实现...

    WebService技术讲义

    ### WebService技术讲义 #### 一、Web Service 引入背景及原因 WebService技术的出现,源于商业世界中日益增长的需求与挑战。随着全球化进程的加速,企业间跨地域、跨系统的协作变得愈发频繁。传统的企业应用集成...

    基于XML的SOAP_WebService分布式系统架构的研究和实现

    基于XML的SOAP/WebService架构的技术细节 ##### 2.1 XML技术 XML(Extensible Markup Language,可扩展标记语言)是一种用于标记数据的标准,它由W3C组织于1998年发布。XML继承了SGML的强大功能,并结合了HTML的...

    webservice简介及架构

    Web服务(Web Service)是一种基于互联网的、采用标准的XML(Extensible Markup Language)进行通信的技术,它允许不同系统间的应用程序进行交互。本篇将深入探讨Web服务的概念、架构及其在Java环境中的实现。 Web...

    IBM webservice 架构理念

    通过对架构的不同层面进行详细阐述,IBM为开发人员和架构师提供了一套全面的方法论,帮助他们更好地理解和应用Web服务技术。此外,IBM还指出了未来的发展方向,如安全性、可靠性等方面的技术改进,为Web服务领域的...

    Webservice架构,基于axis

    Web服务(Webservice)是一种在不同操作系统和编程语言之间进行通信的技术标准,它允许程序通过HTTP协议访问远程对象,使得不同系统之间的数据交换更加灵活和高效。Webservice架构的核心在于提供一个平台无关、语言...

    完整的webservice架构源代码

    本资源提供的"完整的webservice架构源代码"是一个可以直接运行的Web服务示例,对于理解Web服务的工作原理以及开发实践具有很高的参考价值。 在Web服务中,SOAP(Simple Object Access Protocol)是主要的消息协议,...

    java webservice实例教程PPT

    java webservice实例教程ppt,共15讲,java webservice实例教程适合对象:想要学习SOA面向服务编程思想,学习Webservice技术,希望学习系统间通信设计的Java设计开发人员。java webservice实例教程适合于各个层次的...

    基于Webservice的数据访问.docx

    基于 Webservice 的数据访问技术 Webservice 工作原理 Webservice 是一种基于网络的远程过程调用(RPC)技术,允许不同的应用程序之间通过网络进行通讯和交互。Webservice 工作原理可以分为两种:通过 Socket 实现...

    基于Webservice的信息查询系统

    在基于Webservice的信息查询系统中,可以使用Webservice技术来实现信息的集成和查询。例如,可以使用Webservice来查询旅游城市信息、天气预报、人民币汇率和手机号码归属地等信息。同时,也可以使用Webservice来实现...

    webservice获取List案例

    这个场景在分布式系统、微服务架构或者跨平台数据共享中非常常见。让我们深入探讨一下相关的知识点。 1. **WebService**:WebService是一种基于标准的、平台无关的通信协议,使用XML(可扩展标记语言)作为数据交换...

    webService

    首先,我们需要理解WebService的基本架构。一个完整的WebService通常包含以下几个关键部分: 1. WSDL(Web Service Description Language):这是WebService的接口定义语言,用于描述服务提供的操作、输入和输出...

Global site tag (gtag.js) - Google Analytics