Web服务

✍ dations ◷ 2025-04-26 09:26:07 #Web服务

Web服务是一种服务导向架构的技术,通过标准的Web协议提供服务,目的是保证不同平台的应用服务可以互操作。

根据W3C的定义,Web服务(Web service)应当是一个软件系统,用以支持网络间不同机器的互动操作。网络服务通常是许多应用程序接口(API)所组成的,它们透过网络,例如国际互联网(Internet)的远程服务器端,执行客户所提交服务的请求。

尽管W3C的定义涵盖诸多相异且无法介分的系统,不过通常我们指有关于主从式架构(Client-server)之间根据SOAP协议进行传递XML格式消息。无论定义还是实现,Web服务过程中会由服务器提供一个机器可读的描述(通常基于WSDL)以辨识服务器所提供的WEB服务。另外,虽然WSDL不是SOAP服务端点的必要条件,但目前基于Java的主流Web服务开发框架往往需要WSDL实现客户端的源代码生成。一些工业标准化组织,比如WS-I,就在Web服务定义中强制包含SOAP和WSDL。

考虑到并没某个独立文档包含一切相关内容,可采用模块化的方式给出对Web服务的描述,但不能给出一个“绝对全面和准确”的定义。受外部环境和实现技术影响,各方给出的核心定义可能稍有出入,但通常包括:

这些标准由这些组织制订:W3C负责XML、SOAP及WSDL;OASIS负责UDDI。

为提高Web服务间的互操作能力,WS-I还特别发布了WEB服务协议集(Profile)。协议集包含了一系列特定版本的核心定义(诸如SOAP和WSDL),以及对其使用上的限制与约束。WS-I还发布了用于部署协议集兼容WEB服务的测试工具及相关用例。

为扩展WEB服务能力,一些新的标准已经或正在被开发。这些标准通常被冠以WS字头(Web Service的简称),以下是一个WS系列追加标准的不完全列表:

一直以来,W3C负责制定了不少WS追加定义,但近来此举开始受到怀疑。一些人呼吁W3C作为网络和语义网构建者应当把精力放在核心网络本身,而不是为Web服务改换版本。特别是2007年2月的企业级Web服务论坛上,对W3C不再充当WEB服务定义者的诉求开始表面化。此外,OASIS对Web服务扩展实施了许多标准化工作。包括Web服务资源框架以及WSDM。

Web服务实际上是一组工具,并有多种不同的方法调用之。三种最普遍的手段是:远程过程调用(RPC),服务导向架构(SOA)以及表述性状态转移(REST)。

Web服务提供一个分布式函数或方法接口供用户调用,这是一种比较传统的方式。通常,在WSDL中对RPC接口进行定义(类似于早期的XML-RPC)。

尽管最初的Web服务广泛采用RPC方式部署,但针对其过于紧密之耦合性的批评声也随之不断。这是因为RPC式WEB服务实质上是利用一个简单的映射,以把用户请求直接转化成为一个特定语言编写的函数或方法。如今,多数服务提供商认定此种方式在未来将难有作为,在他们的推动下,WS-I基本协议集(WS-I Basic Profile)已不再支持远程过程调用。

现在,业界比较关注的是遵从服务导向架构(Service-oriented architecture,SOA)概念来构筑WEB服务。在服务导向架构中,通讯由消息驱动,而不再是某个动作(方法调用)。这种WEB服务也被称作面向消息的服务。

SOA式WEB服务得到了大部分主要软件供应商以及业界专家的支持和肯定。作为与RPC方式的最大差别,SOA方式更加关注如何去连接服务而不是去特定某个实现的细节。WSDL定义了联络服务的必要内容。

表述性状态转移式(Representational state transfer,REST)Web服务类似于HTTP或其他类似协议,它们把接口限定在一组广为人知的标准动作中(比如HTTP的GET、PUT、DELETE)以供调用。此类WEB服务关注与那些稳定的资源的互动,而不是消息或动作。

此种服务可以通过WSDL来描述SOAP消息内容,通过HTTP限定动作接口;或者完全在SOAP中对动作进行抽象。

一些人抱怨,Web服务(具象化状态转移式除外)过于复杂,认为它太过于偏重那些大型软件开发商,而不利于开源项目。但是至今不少开发工具已经具备自动化产生具象物件,已经减少web服务的调用难度。例如Microsoft Visual Studio、Eclipse等等集成开发环境(IDE)工具。使用者只需要专注于调用与实行。


Web服务的性能也时常是人们关注的一个问题。由于使用XML作为消息格式,并以SOAP封装,由HTTP传输,Web服务始终处于较高的开销状态。不过目前一些新兴技术正在试图解决此一问题,诸如新的XML处理模型致力于解决XML这一部分的性能。

无论是在Web服务出现以前,还是现在,一直不断有各种同类技术问世。比如,RMI作为这样一种中间件系统就得到了广泛部署。CORBA和DCOM则更加雄心壮志,两者都尝试将作用域波及到分布式对象,这一点也为Web服务所模仿。

这些类似方式往往借助于XML-RPC和HTTP本身,而不依靠SOAP封装参数。

相关

  • 世界结核病日世界结核病日(英语:World Tuberculosis Day,或译世界防治结核病日)定于每年的3月24日,是纪念1882年德国微生物学家罗伯特·科霍向一群德国柏林医生发表他对结核病病原菌的发现。
  • SPARQLSPARQL(读做“sparkle”、“史巴–抠”)是一种用于资源描述框架上的查询语言,它的名字是一个递归缩写,代表“SPARQL Protocol and RDF Query Language(SPARQL协议与RDF查询语言)”
  • 佛罗伦萨手抄本《新西班牙事物通史》(西班牙语:Historia general de las Cosas de Nueva España)是16世纪西班牙方济各会修士贝尔纳迪诺·德萨阿贡(Bernardino de Sahagún)所作的民族志文献,使
  • 笔谈笔谈(日语:筆談,韩语:필담,越南语:Bút đàm),是指人们在面对面的情况下不使用口头语言(对话、交谈)而是通过互相书面书写或键盘输入文字(书面语言)的方式,来传达彼此意思的沟通行为,相对
  • 奇蹄目 Perissodactyla奇蹄目(学名:Perissodactyla)是哺乳动物中的一个目,包括有奇数脚趾的动物。原始奇蹄动物前足四趾,后足三趾,现生的奇蹄动物貘就是这样的脚趾结构。草食,胃的构造和偶蹄目部分成员多
  • 拉格朗日点拉格朗日点(Lagrangian point)又称平动点(libration points)在天体力学中是限制性三体问题的五个特殊解(particular solution)。就平面圆型三体问题,1767年数学家欧拉根据旋转的二
  • 氪气3d10 4s2 4p62, 8, 18, 8蒸气压第一:1350.8 kJ·mol−1 第二:2350.4 kJ·mol−1 第三:3565 kJ·mol主条目:氪的同位素氪是一种化学元素,化学符号是Kr,原子序数是36,是一种无色
  • 审计风险审计风险(Audit risk)是一个通常用于财务报表审计的术语。财务报表审计的目的是对“财务报表是否已按照恰当的会计准则编制并在所有重大方面公允反映了被审计者的财务信息”发
  • 毛德皇后地南极洲(白色)毛德皇后地(英语:Queen Maud Land),南极洲大陆东部一区域,位于西经20度至东经45度之间,面积约为250万平方公里,挪威于1938年1月14日对其提出主权要求,但根据南极条约被冻
  • 铸币税铸币税(英文:Seigniorage)亦称货币税,指发行货币的组织或国家的政府,享有货币发行面值减去发行成本后,换取实际经济资源的利益,从中攫取发行货币所产生的特定收益。这部分由货币发