方法 : カスタム WSDL をインポートする
このトピックでは、カスタム WSDL をインポートする方法について説明します。カスタム WSDL を処理するには、IWsdlImportExtension インターフェイスを実装する必要があります。
カスタム WSDL をインポートするには
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."); } }
カスタム 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>
新しい WsdlImporter インスタンス (インポートする WSDL ドキュメントが含まれる MetadataSet インスタンスを渡す) を作成し、ImportAllContracts を呼び出します。
WsdlImporter importer = new WsdlImporter(metaDocs); System.Collections.ObjectModel.Collection<ContractDescription> contracts = importer.ImportAllContracts();