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) |
Вызывается при импорте конечной точки. |