重整山河待后生:Web Services

2023-10-12 17:50

本文主要是介绍重整山河待后生:Web Services,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Web Services,一词有广义和狭义之分。狭义而言,其表示一种特定的,基于SOAP协议Web服务技术(SOAP Web Services)。广义而言,泛指各种类型的Web服务,而不特指其实现方式,不仅包含SOAP Web Service,也包括Restful的API(被称作 Restful Web Services)。当然了,Web Services(以下简称WS)这个词用的最多的就是其狭义的含义,而本文也基于此。

1. WS 与 SOA、RPC

从思想上看,WS属于SOA组件模型的一种具体实现。SOA即 Service-Oriented Architecture(面向服务的架构),并非一种具体而言的技术体系,而是一种服务化架构设计的思想。其实现形式多种多样(WS只是接入层SOA的一种实现),现已广泛应用于各大企业的后台之中。

从用法上看,WS是一种RPC技术。RPC即 Remote Procedure Call(远程过程调用),简单而言RPC可以概况为:“就像调用本地的类和函数(方法)一样,来调用远程的类以及函数(方法)”。虽然其内部仍旧是通过TCP或HTTP来通信的,但是其通信过程对于程序员来说是透明的。程序员无需关系其具体的通信细节,只需要向执行普通的类和函数一样去执行就可以了。另一种著名的RPC实现是RMI,只不过RMI的服务端和客户端都限制为Java语言实现,而WS则不限语言。

2. 三剑客

WS技术体系包含三大组成部分:SOAP、WSDL、UDDI。

2.1 SOAP

看名字SOAP和上文的SOA很像,但其意却大相径庭。SOAP全称 Simple Object Access Protocol(简单对象访问协议)。其本质是描述了在一个RPC过程中对象传递的规范(谷歌Protocol Buffers也是基于同样目的)。

具体而言SOAP协议只描述两部分内容:一是介质,二是格式。格式就是一种特定的XML格式,而介质即承载该格式的网络协议,可以是HTTP/HTTPS、TCP、UDP、SMTP甚至JMS。当然最流行的就是基于HTTP的了。基于HTTP的SOAP,其Content-Type为 application/soap+xml。

(本系列文章将WS一文放置到【接入层】部分,正是由于SOAP WS主要是基于HTTP的,而基于其他介质的SOAP WS,并不一定处于接入层!)

SOAP是一种特殊的XML格式,他主要包含两个元素:Envelope 和 Body。包含<soap:Envelope>和<soap:Body>的XML才是合法的SOAP格式。另外还有两个可选元素:Header 和 Fault。Body元素中包含了向服务端请问的函数名,参数等信息。

&lt;?xml version="1.0"?&gt;	
&lt;soap:Envelope	
xmlns:soap="http://www.w3.org/2001/12/soap-envelope"	
soap:encodingStyle="http://www.w3.org/2001/12/soap-encoding"&gt;	&lt;soap:Body&gt;	&lt;m:GetPrice xmlns:m="http://www.w3schools.com/prices"&gt;	&lt;m:Item&gt;Apple&lt;/m:Item&gt;	&lt;/m:GetPrice&gt;	
&lt;/soap:Body&gt;	&lt;/soap:Envelope&gt; 

如上述实例所示,请求的函数为GetPrice,函数参数名Item,参数值为Apple。

完整的请求响应实例,请参照:SOAP Body

2.2 WSDL

由于客户端编码接入WS还是过于繁复,所以SOAP WS体系的一大组成部分就是 WSDL(Web Services Description Language)。WSDL是一种IDL(接口描述语言)。服务端通过UDDI发布WSDL文件,客户端通过WS编译工具(比如wsimport)编译WSDL,得到stub代码(桩代码:客户端代码接入WS的大体框架,程序员只需要编写逻辑)。

WSDL其格式也是一种定制XML。其主要功能就是描述了函数(方法)接口。这样利用编译工具即可编译出服务端函数的stub,然后客户端就像调用本地函数那样调用服务端的WS函数啦。wsdl格式非三言两语说清,详细描述也脱离本系列文章形而上的宗旨。大家自行谷歌,或者参考阅读如下实例,天气服务wsdl:

webxml.com.cn/WebServic

wsimport是JDK自带的工具,可以编译本地或互联网(通过URL)上的WSDL。另外CXF包含一个wsdl2java的工具,和wsimport类似。

注解:

  • IDL一词出自CORBA,但是后来其含义已范化。

  • CXF是Apache基金会针对Java WS的一个工具包(库)。丰富了Java WS的功能。

2.3 UDDI

分布式系统中必不可少却又常常为人所忽略的一个服务是:命名服务。笔者个人认为当今互联网最成功的命名服务莫过于DNS和URL了。大型企业内部网络也建有拥有各自系统特色的命名服务。SOAP WS要实现制霸的梦想,理所应当的发明了自己的命名服务:UDDI。

UDDI:通用描述发现和集成 (Universal Description, Discovery, and Integration)

ws服务端开发完成之后需要向UDDI注册,并发布,这一过程中每个WS会或者一个UUID。发布之后其他人才可见。而接入WS的客户端程序,也需要通过UDDI注册中心的分发路由到相应的WS,然后将响应返回给客户端。当然其实际过程比我文字概括的要复杂的多,请见下图:

640?wx_fmt=jpeg

(图片来源于网络)

3. 重整山河待后生

其实通过对WS是三大组件的介绍,可以发现WS与之前的CORBA技术有很多相似之处。同样是一种RPC,传递对象,并且使用IDL(接口定义语言,WSDL之于WS)生成stub桩代码。

在上个世纪90年代,随着RPC概念的兴起,CORBA技术逐渐走入人们的视野,这是OMG组织发布的一个雄心勃勃的标准。但历史总是相似,就像学术界的ISO/OSI七层参考模型一样,最终被工业界的TCP/IP取代。CORBA也由于种种原因,在推广后呈现出种种的水土不服。后来以微软、IBM为首的公司开始力推WS,由于各位大佬的加持,WS曾红极一时。

但WS也并非完全没有问题,各家厂商之间的标准并非完全一致,真正达到完美跨语言的RPC还是过于乐观。另外WS使用过程(接入以及发布等)中的复杂度让许多人望而却步。尽管WS出发点是让程序员从异构系统的跨网络通信过程中解放出来,专注于业务逻辑。但是为实现这一目标却又引入了另一维度的复杂度。

进入新世纪,网络规模日益扩大。各类公共的服务接口层出不穷,看似是WS技术最为拿手的场景。但最终人们开始回归初心,从新出发。不再纠结RPC,不再自制目录服务。利用已有的HTTP和URL,借着JS与Ajax的春风,API技术逐渐成为公认的Web服务接口的实现方式。

未来技术如何更迭尚未可知,但在抚今追昔,寻觅技术发展轨迹的过程中可以发现,没有任何一种技术能长盛不衰,而一门过时的技术也可能重新被炒起冷饭。

长江后浪推前浪,重整山河待后生。


推荐阅读

Web Services教程

Introducing SOAP and JAX-WS (54m29s)

理解UDDI

这篇关于重整山河待后生:Web Services的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/197474

相关文章

解决JavaWeb-file.isDirectory()遇到的坑问题

《解决JavaWeb-file.isDirectory()遇到的坑问题》JavaWeb开发中,使用`file.isDirectory()`判断路径是否为文件夹时,需要特别注意:该方法只能判断已存在的文... 目录Jahttp://www.chinasem.cnvaWeb-file.isDirectory()遇

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

Java Web指的是什么

Java Web指的是使用Java技术进行Web开发的一种方式。Java在Web开发领域有着广泛的应用,主要通过Java EE(Enterprise Edition)平台来实现。  主要特点和技术包括: 1. Servlets和JSP:     Servlets 是Java编写的服务器端程序,用于处理客户端请求和生成动态网页内容。     JSP(JavaServer Pages)

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

9.8javaweb项目总结

1.主界面用户信息显示 登录成功后,将用户信息存储在记录在 localStorage中,然后进入界面之前通过js来渲染主界面 存储用户信息 将用户信息渲染在主界面上,并且头像设置跳转,到个人资料界面 这里数据库中还没有设置相关信息 2.模糊查找 检测输入框是否有变更,有的话调用方法,进行查找 发送检测请求,然后接收的时候设置最多显示四个类似的搜索结果

JavaWeb【day09】--(Mybatis)

1. Mybatis基础操作 学习完mybatis入门后,我们继续学习mybatis基础操作。 1.1 需求 需求说明: 根据资料中提供的《tlias智能学习辅助系统》页面原型及需求,完成员工管理的需求开发。 通过分析以上的页面原型和需求,我们确定了功能列表: 查询 根据主键ID查询 条件查询 新增 更新 删除 根据主键ID删除 根据主键ID批量删除