IWsdlImportExtension Интерфейс

Определение

Реализация и присоединение к объекту WsdlImporter служит для управления способами, которыми средства импорта сопоставляют части WSDL с частями объекта ServiceDescription.

public interface class IWsdlImportExtension
public interface IWsdlImportExtension
type IWsdlImportExtension = interface
Public Interface IWsdlImportExtension
Производный

Примеры

В следующем примере кода показано использование IWsdlImportExtension добавления System.ServiceModel.Description.IServiceContractGenerationExtension и System.ServiceModel.Description.IOperationContractGenerationExtension ( WsdlDocumentationImporterв данном случае) для изменения созданного клиентского кода WCF на уровне интерфейса и операции.

  public void ImportContract(WsdlImporter importer, WsdlContractConversionContext context)
  {
Console.Write("ImportContract");
      // 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));
              }
          }
      }
  }

В следующем примере кода показано, как настроить систему метаданных клиента для использования настраиваемого IWsdlImportExtension из файла конфигурации приложения.

<system.serviceModel>
    <client>
      <endpoint 
        address="http://localhost:8000/Fibonacci" 
        binding="wsHttpBinding"
        contract="IFibonacci"
      />
      <metadata>
        <wsdlImporters>
          <extension type="Microsoft.WCF.Documentation.WsdlDocumentationImporter, WsdlDocumentation, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" />
        </wsdlImporters>
      </metadata>
    </client>
  </system.serviceModel>

Комментарии

Реализация интерфейса IWsdlImportExtension служит для управления сопоставлениями между WSDL и объектами ServiceEndpoint и ContractDescription, особенно при чтении настраиваемых расширений WSDL для изменения сведений о контракте или конечной точке. Затем необходимо присоединить настраиваемый объект IWsdlImportExtension к WsdlImporter программно или с помощью файла конфигурации приложения. Вы также можете подключить пользовательский IWsdlImportExtension объект к внутреннему WsdlImporter объекту, используемому служебной программой метаданных ServiceModel (Svcutil.exe), с помощью файла конфигурации приложения.

Метод ImportContract вызывается для импортирования контракта.

Метод BeforeImport используется для изменения метаданных, которые впоследствии импортируются в объекты ServiceEndpoint и ContractDescription.

Методы

BeforeImport(ServiceDescriptionCollection, XmlSchemaSet, ICollection<XmlElement>)

Вызывает перед импортом документов метаданных.

ImportContract(WsdlImporter, WsdlContractConversionContext)

Вызывается при импорте контракта.

ImportEndpoint(WsdlImporter, WsdlEndpointConversionContext)

Вызывается при импорте конечной точки.

Применяется к