Практическое руководство. Импорт пользовательской информации WSDL
В этом разделе описывается, как импортировать пользовательский код WSDL. Для работы с пользовательским кодом WSDL необходимо реализовать интерфейс IWsdlImportExtension.
Импорт пользовательского кода WSDL
Реализуйте расширение 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."); } }
Настройте клиентское приложение, чтобы оно использовало пользовательский импортер 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>
Создайте новый экземпляр WsdlImporter (передав ему экземпляр MetadataSet, содержащий документы WSDL, которые требуется импортировать) и вызовите метод ImportAllContracts:
WsdlImporter importer = new WsdlImporter(metaDocs); System.Collections.ObjectModel.Collection<ContractDescription> contracts = importer.ImportAllContracts();