WebService,ESB笔记
一、WebService是什么?
WebService,是RPC的一样实现方式。
RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议
客户端要能调用服务端必须遵循TCP协议,而WebService使用的是更高一级的HTTP协议。
客户端访问服务器的目的是为了获取数据,那数据格式必须是与平台、语言无关的。WebService采用的是XML.
WebService的使用场景:ESB(企业服务总线)
如果一个企业存在多个使用不同语言开发的在用系统,数据传递和整合就显得尤其麻烦,利用传统连接各个系统的方法,存在如果新添加一个系统,都需要和每一个已经存在的系统建立关联,集成系统的时候入侵性太强,往往伴随着整体系统结构的改变。
所以在这种场景下,可在企业系统里搭建一根总线——ESB(企业服务总线),用来连接企业里各个系统的服务的。每个系统和总线连接起来,用XML传输数据。
把各系统连接到总线上以后,例如查询销售单,把请求抛给总线,由总线负责把消息带到进销存系统中去,再把结果按照应的规范传到总线上,由总线负责把结果返回到财务系统中。若要增加额外的系统,如WebQQ,就只需要把他挂到ESB上就OK了。ESB也是一个应用模块,负责把每个系统连接起来。
ESB全称为EnterpriseServiceBus,即企业服务总线。
它是传统中间件技术与XML、Web服务等技术结合的产物。ESB提供了网络中最基本的连接中枢,是构筑企业神经系统的必要元素。ESB的出现改变了传统的软件架构,可以提供比传统中间件产品更为廉价的解决方案,同时它还可以消除不同应用之间的技术差异,让不同的应用服务器协调运作,实现了不同服务之间的通信与整合。从功能上看,ESB提供了事件驱动和文档导向的处理模式,以及分布式的运行管理机制,它支持基于内容的路由和过滤,具备了复杂数据的传输能力,并可以提供一系列的标准接口。
ESB不是万能的,他不是一个应用程序框架,也不是一个企业应用的解决方案.它只是一个基于消息的调用企业服务的通信模块!你可以把它嵌入到你的应用程序框架中,例如嵌入到spring容器里面,或者嵌入到工作流系统中.它的作用是对企业里面的SOA服务的调用提供一个框架和简便的方法。
SOA
对于这一种架构,我们称为SOA:面向服务的架构。要使用总线上挂的各个服务则需要对暴露的接口做一个描述。
第一,ESB怎么知道有哪些什么样服务?那此时我们就得对暴露出去的服务做一个描述,而这个描述就是WSDL。
WSDL(WebServicesDescriptionLanguage):WS的描述语言。告诉总线自己暴露了哪些服务。
第二,查询:我暴露了这个服务,要找到他则需要一个类似于DNS这样的东西,用于服务的注册、查询,而这个就是UDDI。
UDDI(Universal Description,Discovery andIntegration):是一种目录服务,用于统一地描述、发现和集成协议。UDDI定义如何查找WS(及其WSDL文件),可它并不像WSDL和SOAP一样深入人心,因为很多时候,使用者都知道Web服务的位置(通常位于公司的企业内部网中)。
第三,传输数据:定义数据传输规范,这里都使用XML进行传递,把对象和XML进行转换由SOAP规范。
SOAP(Simple Object Access Protocol):简单对象访问协议。是一种轻量的、简单的、基于XML的协议,它被设计成在WEB上交换结构化的和固化的信息。
二、关于WebService
WS是一种基于Http协议和XMl技术,并使用WSDL描述和使用SOAP协议传输的异构系统解决方案。 跨语言、跨系统
我们把调用WS的应用程序称为客户端,把提供WS的应用程序称为服务器端。
使用WS最重要的是什么:
一是:WSDL文件(服务藐视);
二是:对象与XML转换(数据)。
WS和SOA的区别:
Web Service是技术规范,而SOA是设计原则,一种架构模式。
WSDL,UDDI和SOAP是SOA基础的基础部件。
WSDL:用来描述服务;
UDDI:用来注册和查找服务;
SOAP:作为传输层,用来在客户端和服务器端之间传送消息。
三、关于WebService的常见标签
1、 @WebService标签
使用@WebService标签,需要配置在类上,代表这是一个提供WS的服务类。
endpointInterface:定义服务抽象WebService 协定的服务端点接口的完整名称。不允许在端点上使用此成员值,该元素的值必须有WebService标签。默认情况下,服务器自动生成服务端接口。
name:服务接口名称(对应wsdl: portType的name属性,用在服务接口上);
serviceName:服务类名称。默认为,实现类名+Service(对应service的name和definition上的name属性对应,用在实现类上)。
portName:Web Service的端口名称。此名称被用作wsdl:port的名称。
targetNamespace:目标命名空间,描述服务的预定义WSDL的位置(同时用在实现类和服务接口上,需统一)。
wsdlLocation:WSDL地址(服务端除了WSDL优先的情况外可不写,客户端代理接口上必须配置此属性,指向web端WSDL文件地址)
2 @WebMethod标签
使用@WebMethod标签,需要把他配置到方法上。
operationName:指定暴露服务方法的别名。
exclude:是否暴露此标记的方法。
3 @WebResult标签
使用@WebResult标签,需要把他标记在方法上或者方法返回类型定义之前。
name:定义返回值的名称。
header:布尔类型,是否把值放到header元素中进行传递。
4 @WebParam标签
使用@WebParam标签,需要把他标记在形参声明之前。
name:定义传递时参数的名称(默认参数以arg0,arg1…)。
header:布尔类型,是否把值放到header元素中进行传递。
5 @SOAPBinding
使用@ SOAPBinding标签,需要把他标记在类上。
SOAPBinding.ParameterStyleparameterStyle 确定方法参数是否表示整个消息正文,或者参数是否是包装在以操作命名的顶层元素中的元素。
SOAPBinding.ParameterStyle.WRAPPED,默认,使用对参数进行包装
SOAPBinding.ParameterStyle.BARE,不对参数进行包装
SOAPBinding.Style style 定义发 送到Web Service 的消息 和从Web Service发送的消息的编码样式。
SOAPBinding.Style.RPC:面向RPC
SOAPBinding.Style.DOCUMENT 默认,面向文档
SOAPBinding.Useuse 定义发送到WebService的消息和从WebService发送的消息的格式样式。
SOAPBinding.Use.LITERAL,默认,字面量风格,若服务端和客户端不在一起开发,就应该使用这个
SOAPBinding.Use.ENCODED使用SOAP编码风格,可能导致WS互操作方面失败问题,尽量避免使用。
WebService,ESB笔记的更多相关文章
- WebService学习笔记系列(二)
soap(简单对象访问协议),它是在http基础之上传递xml格式数据的协议.soap协议分为两个版本,soap1.1和soap1.2. 在学习webservice时我们有一个必备工具叫做tcpmon ...
- Java WebService学习笔记 - Axis进阶(二)
上一篇 Java WebService学习笔记 - Axis(一) 前一篇博文中简单介绍了Axis的使用方法,这篇将介绍一些Axis的一些高级特性 Axis中Handler的使用 Handler ...
- Java WebService学习笔记 - Axis(一)
WebService 简介 实际开发中,很多系统都是基于历史遗留系统进行开发,有时,这些系统基于不同的语言,如C,C++,C#,java,PHP等等.为了实现历史系统的再利用,或向外部程序暴露调用接口 ...
- webservice 学习笔记 1
Webservice----------->跨语言服务调用 (视频学习总结) 1-1.有OA系统 需要添加一个功能,登录之后显示天气情况 此时可以使用Webservice eg1: 气象局自己有 ...
- webservice 学习笔记
1.webservice的概念 Web Service也叫XML Web Service WebService是一种可以接收从Internet或者Intranet上的其它系统中传递过来的请求,轻量级的 ...
- WebService学习笔记一
01——Schema约束复习 1.1 schema约束 几个重要知识: 1.namespace 相当于schema文件的id 2.targetNamespace属性 用来指定schema文件的name ...
- WebService学习笔记系列(四)
今天主要来看看服务端的编写及发布. 服务端的编写主要包括三个步骤: 1.编写一个接口,即SEI(server endpoint interface) 2.编写接口的实现类,即SIB (server i ...
- WebService学习笔记系列(三)
网上有一些提供webservice服务的网站,我们要怎么调用呢? 今天来看个如何调用手机归属地查询服务.这个网站上提供了许多webservice服务,其中包括手机归属地查询服务,我们今天就用wsimp ...
- WebService学习笔记系列(一)
webservice主要是解决两个系统或者两个应用程序之间的远程调用,它提供了一种通过web方式访问的api,调用是跨语言.跨平台的. webservice的客户端与服务端进行交互的时候使用xml来传 ...
随机推荐
- php 日期处理 DateTime
获取所有的时区: print_r(timezone_abbreviations_list ()); 获取毫秒级时间戳 // php7.1+ always has microseconds enable ...
- Debug 路漫漫-07
201811—201903??? 1)关于训练参数是复数的问题 ——q_k ^theta q_k(是item的特征矩阵)中有可能是负数,而指数 theta 如果是含小数点的话,就会产生复 ...
- SQL注入学习资料总结
转载自:https://bbs.ichunqiu.com/thread-12105-1-1.html 什么是SQL注入 SQL注入基本介绍 结构化查询语言(Structured Query Lang ...
- Web API 异常处理
Web Api的ExceptionFilter只能截获并处理Action执行过程中发生的异常,在Action执行过程之外如果出现异常,ExceptionFilter是无能为力的. 这些异常包括: 1. ...
- Elasticsearch index fields 重命名
reindex数据复制,重索引 POST _reindex { "source": { "index": "twitter" }, &quo ...
- selenium.common.exceptions.UnexpectedAlertPresentException: Alert Text: None;Message: unexpected alert open: {Alert text : 您点击的频率过快!请稍后再试}
报错 Traceback (most recent call last): File "C:/myFiles/code/cnki/cnki_1/core/knavi.py", li ...
- Deseq2 的可视化策略汇总
1) MA图 对于MA图而言, 横坐标为该基因在所有样本中的均值,basemean = (basemean_A + basemean_B ) / 2, 纵坐标为 log2Fold change 其 ...
- Houdini技术体系 基础管线(四) :Houdini驱动的UE4植被系统 上篇
背景 之前在<Houdini技术体系 过程化地形系统(一):Far Cry5的植被系统分析>一文中已经对AAA游戏中过程化植被的需求有了一定的定义,后续工作就是如何用Houdini开发功能 ...
- 内建模块collections的使用
# -*-coding:utf-8 -*- from collections import namedtuple Point=namedtuple('Point',['x','y']) p=Point ...
- [hbase] hbase 基础使用
一.准备 hadoop 2.8.0 (提前配置好) hbase 1.2.6 zookeeper 3.4.9 (配置完成) jdk1.8 hadoop 集群信息: zk集群: 二.安装配置 1.下载(官 ...