Поделиться через


Практическое руководство. Импорт пользовательской информации WSDL

В этом разделе описывается, как импортировать пользовательский код WSDL. Для работы с пользовательским кодом WSDL необходимо реализовать интерфейс IWsdlImportExtension.

Импорт пользовательского кода WSDL

  1. Реализуйте расширение IWsdlImportExtension. Реализуйте метод BeforeImport(ServiceDescriptionCollection, XmlSchemaSet, ICollection<XmlElement>), чтобы он изменял метаданные перед их импортом. Реализуйте методы ImportEndpoint(WsdlImporter, WsdlEndpointConversionContext) и ImportContract(WsdlImporter, WsdlContractConversionContext), чтобы они изменяли контракты и конечные точки, импортированные из метаданных. Чтобы обратиться к импортированному контракту или конечной точке, следует использовать соответствующий объект контекста (WsdlContractConversionContext или WsdlEndpointConversionContext):

    public class WsdlDocumentationImporter : IWsdlImportExtension
    {
        public void ImportContract(WsdlImporter importer, WsdlContractConversionContext context)
        {
            // Contract documentation
            if (context.WsdlPortType.Documentation != null)
            {
                context.Contract.Behaviors.Add(new WsdlDocumentationImporter(context.WsdlPortType.Documentation));
            }
            // Operation documentation
            foreach (Operation operation in context.WsdlPortType.Operations)
            {
                if (operation.Documentation != null)
                {
                    OperationDescription operationDescription = context.Contract.Operations.Find(operation.Name);
                    if (operationDescription != null)
                    {
                        operationDescription.Behaviors.Add(new WsdlDocumentationImporter(operation.Documentation));
                    }
                }
            }
        }
    
        public void BeforeImport(ServiceDescriptionCollection wsdlDocuments, XmlSchemaSet xmlSchemas, ICollection<XmlElement> policy)
        {
            Console.WriteLine("BeforeImport called.");
        }
    
        public void ImportEndpoint(WsdlImporter importer, WsdlEndpointConversionContext context)
        {
            Console.WriteLine("ImportEndpoint called.");
        }
    }
    
  2. Настройте клиентское приложение, чтобы оно использовало пользовательский импортер WSDL. Обратите внимание, что при использовании средства Svcutil.exe соответствующие параметры необходимо задать в файле конфигурации этого средства (Svcutil.exe.config):

    <system.serviceModel>  
          <client>  
            <endpoint
              address="http://localhost:8000/Fibonacci"
              binding="wsHttpBinding"  
              contract="IFibonacci"  
            />  
            <metadata>  
              <wsdlImporters>  
                <extension type="Microsoft.WCF.Documentation.WsdlDocumentationImporter, WsdlDocumentation" />  
              </wsdlImporters>  
            </metadata>  
          </client>  
        </system.serviceModel>  
    
  3. Создайте новый экземпляр WsdlImporter (передав ему экземпляр MetadataSet, содержащий документы WSDL, которые требуется импортировать) и вызовите метод ImportAllContracts:

    WsdlImporter importer = new WsdlImporter(metaDocs);
    System.Collections.ObjectModel.Collection<ContractDescription> contracts = importer.ImportAllContracts();  
    

См. также