- 服务元数据是用来获得服务的EndPoint的信息,也就是它的ABC.
- 服务有两种方案可以发布自己的元数据。
- 一种是基于HTTP-GET协议提供元数据;
- 一种是元数据交换方式,它往往使用一个专门的终结点,称之为元数据交换终结点。元数据交换终结点与其它终结点相似,仍然包含了地址、绑定与契约,但是使用的服务契约为WCF提供的接口ImetadataExchange.实际上是使用了两种协议: 前者为HTTP/GET请求,后者为WS-MetadataExchange(MEX). 以MetadataExchangeClientMode枚举类型表示这两种元数据交换模式(MetadataExchange, HttpGet).
- 获取EndPoint,使用抽象类MetadataImporter.
- ImportAllEndpoints()来返回所有的终结点的集合,之后我们可以在这个集合中通过契约类型,或者服务契约的地址,查找符合条件的终结点.
- 如果要获取WSDL元数据,还会需要使用继承它的子类型WsdlImporter. 需要为其构造函数传递一个MetadataSet类型的对象。而MetadataSet类型的对象则可以通过MetadataExchangeClient类的GetMetadata()方法获得.假定服务公开的元数据地址为http://localhost:8001/IMyService?wsdl,则获取服务元数据的方法如下:
- string mexAddress = “http://localhost:8001/IMyService?wsdl”;
- BasicHttpBinding binding = new BasicHttpBinding();
- MetadataExchangeClient mexClient = new MetadataExchangeClient(binding);
- MetadataSet metadata = mexClient.GetMetadata(new Uri(mexAddress),MetadataExchangeClientMode.HttpGet);
- MetadataImporter importer = new WsdlImporter(metadata);
- ServiceEndpointCollection endpoints = importer.ImportAllEndpoints();
- 但是如果协议为HTTP/Https,可以使用两种方式暴露,所以,我们可以先获取元数据交换终结点,如果没有找到,再获取基于HTTP-GET的终结点.在获得ServiceEndpointCollection集合对象后,就可以针对每个ServiceEndpoint获取终结点的Address、Binding、Contract的信息.
- 元数据交换终结点,须有对应的绑定来支持。
- MEX终结点可以支持多种不同的传输协议,包括HTTP(S),TCP和Named Pipe,支持MEX传输的绑定的名称分别为mexHttpBinding、mexHttpsBinding、mexTcpBinding、mexNamedPipeBinding,但是却没有相应的绑定类.那些绑定元素并没有分别映射到一个专门的类中,而是统一放到了一个单独的类MetadataExchangeBindings,该类提供了CreateMexHttpBinding, CreateMexHttpsBinding,CreateMexNamedPipeBinding和CreateMexTcpBinding四个方法.查看这些方法的实现,可以发现它们都创建了WCF的内建绑定,然后根据情况调整了某些默认值,并重写了绑定的名称和命名空间.所以,当我们在配置MEX终结点时,使用WCF提供的MEX绑定并非必须的,我们也可以为其指定内建绑定,只要该绑定符合MEX终结点的场景.
相关文章
- 01-09Keras之MLP:利用MLP【Input(8)→(12)(relu)→O(sigmoid+二元交叉)】模型实现预测新数据(利用糖尿病数据集的八个特征实现二分类预测
- 01-09WCF 服务的ABC之绑定(六)
- 01-093. SpringCloud+SpringBoot+Mybatis+Oauth2+数据权限+前后端分离+vue 分布式 微服务 快速开发 企业架构技术总结之Spring Cloud和Dubbo的区别
- 01-09Dynamics 365(online) V9.0 多选选项集之组织服务查询数据过滤及字段赋值
- 01-09WCF之服务元数据
- 01-09dubbo学习实践(5)之Dubbo-Admin元数据中心配置(zookeeper&Redis&Consul)
- 01-09canal之——缓存一致性和跨服务器查询的数据异构解决方案
- 01-09本地无sqlserver服务下操作数据库 之GSQL
- 01-09离线电商数仓(六十)之元数据管理(八)Ranger (三)使用Ranger对Hive进行权限管理
- 01-09ros之自定义服务数据