方法 : カスタム WSDL をインポートする

このトピックでは、カスタム WSDL をインポートする方法について説明します。カスタム WSDL を処理するには、IWsdlImportExtension インターフェイスを実装する必要があります。

カスタム WSDL をインポートするには

  1. IWsdlImportExtension を実装します。BeforeImport メソッドを実装してメタデータをインポートする前に変更します。ImportEndpoint メソッドと ImportContract メソッドを実装してメタデータからインポートされたコントラクトとエンドポイントを変更します。インポートしたコントラクトまたはエンドポイントにアクセスするには、対応するコンテキスト オブジェクト (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 の構成ファイル (Svcutil.exe.config) にこの構成を追加する必要があります。

    <system.serviceModel>
          <client>
            <endpoint 
              address="https://localhost:8000/Fibonacci" 
              binding="wsHttpBinding"
              contract="IFibonacci"
            />
            <metadata>
              <wsdlImporters>
                <extension type="Microsoft.WCF.Documentation.WsdlDocumentationImporter, WsdlDocumentation" />
              </wsdlImporters>
            </metadata>
          </client>
        </system.serviceModel>
    
  3. 新しい WsdlImporter インスタンス (インポートする WSDL ドキュメントが含まれる MetadataSet インスタンスを渡す) を作成し、ImportAllContracts を呼び出します。

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

参照

処理手順

カスタム WSDL パブリケーション

概念

メタデータ
メタデータのエクスポートとインポート