WCF之服务元数据

时间:2023-02-13 16:09:06
  • 服务元数据是用来获得服务的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终结点的场景.