ServiceDescription Класс

Определение

Представляет собой полное хранимое в памяти описание службы, включающее все конечные точки для службы и спецификации для соответствующих им адресов, привязок, контрактов и поведений.Represents a complete, in-memory description of the service, including all the endpoints for the service and specifications for their respective addresses, bindings, contracts and behaviors.

public ref class ServiceDescription
public class ServiceDescription
type ServiceDescription = class
Public Class ServiceDescription
Наследование
ServiceDescription

Примеры

В следующем примере показаны различные способы создания объекта ServiceDescription.The following example illustrates various ways to instantiate a ServiceDescription object.

           Uri baseAddress = new Uri("http://localhost:8001/Simple");
           ServiceHost serviceHost = new ServiceHost(typeof(CalculatorService), baseAddress);

           serviceHost.AddServiceEndpoint(
               typeof(ICalculator),
               new WSHttpBinding(),
               "CalculatorServiceObject");

           // Enable Mex
           ServiceMetadataBehavior smb = new ServiceMetadataBehavior();
           smb.HttpGetEnabled = true;
           serviceHost.Description.Behaviors.Add(smb);

           serviceHost.Open();

           // Use Default constructor
           ServiceDescription sd = new ServiceDescription();

           // Create ServiceDescription from a collection of service endpoints
           List<ServiceEndpoint> endpoints = new List<ServiceEndpoint>();
           ContractDescription conDescr = new ContractDescription("ICalculator");
           EndpointAddress endpointAddress = new EndpointAddress("http://localhost:8001/Basic");
           ServiceEndpoint ep = new ServiceEndpoint(conDescr, new BasicHttpBinding(), endpointAddress);
           endpoints.Add(ep);
           ServiceDescription sd2 = new ServiceDescription(endpoints);

           // Iterate through the list of behaviors in the ServiceDescription
           ServiceDescription svcDesc = serviceHost.Description;
           KeyedByTypeCollection<IServiceBehavior> sbCol = svcDesc.Behaviors;
           foreach (IServiceBehavior behavior in sbCol)
           {
               Console.WriteLine("Behavior: {0}", behavior.ToString());
           }

           // svcDesc is a ServiceDescription.
           svcDesc = serviceHost.Description;
           string configName = svcDesc.ConfigurationName;
           Console.WriteLine("Configuration name: {0}", configName);

           // Iterate through the endpoints contained in the ServiceDescription
           ServiceEndpointCollection sec = svcDesc.Endpoints;
           foreach (ServiceEndpoint se in sec)
           {
               Console.WriteLine("Endpoint:");
               Console.WriteLine("\tAddress: {0}", se.Address.ToString());
               Console.WriteLine("\tBinding: {0}", se.Binding.ToString());
               Console.WriteLine("\tContract: {0}", se.Contract.ToString());
               KeyedByTypeCollection<IEndpointBehavior> behaviors = se.Behaviors;
               foreach (IEndpointBehavior behavior in behaviors)
               {
                   Console.WriteLine("Behavior: {0}", behavior.ToString());
               }
           }

           string name = svcDesc.Name;
           Console.WriteLine("Service Description name: {0}", name);

           string namespc = svcDesc.Namespace;
           Console.WriteLine("Service Description namespace: {0}", namespc);

           Type serviceType = svcDesc.ServiceType;
           Console.WriteLine("Service Type: {0}", serviceType.ToString());

           // Instantiate a service description specifying a service object
           // Note: Endpoints collection and other properties will be null since 
           // we have not specified them
           CalculatorService svcObj = new CalculatorService();
           ServiceDescription sd3 = ServiceDescription.GetService(svcObj);
           String serviceName = sd3.Name;
           Console.WriteLine("Service name: {0}", serviceName);

Dim baseAddress As New Uri("http://localhost:8001/Simple")
Dim serviceHost As New ServiceHost(GetType(CalculatorService), baseAddress)

serviceHost.AddServiceEndpoint(GetType(ICalculator), New WSHttpBinding(), "CalculatorServiceObject")

' Enable Mex
Dim smb As New ServiceMetadataBehavior()
smb.HttpGetEnabled = True
serviceHost.Description.Behaviors.Add(smb)

serviceHost.Open()

' Use Default constructor
Dim sd As New ServiceDescription()

' Create ServiceDescription from a collection of service endpoints
Dim endpoints As New List(Of ServiceEndpoint)()
Dim conDescr As New ContractDescription("ICalculator")
Dim endpointAddress As New EndpointAddress("http://localhost:8001/Basic")
Dim ep As New ServiceEndpoint(conDescr, New BasicHttpBinding(), endpointAddress)
endpoints.Add(ep)
Dim sd2 As New ServiceDescription(endpoints)

' Iterate through the list of behaviors in the ServiceDescription
Dim svcDesc As ServiceDescription = serviceHost.Description
Dim sbCol As KeyedByTypeCollection(Of IServiceBehavior) = svcDesc.Behaviors
For Each behavior As IServiceBehavior In sbCol
    Console.WriteLine("Behavior: {0}", CType(behavior, Object).ToString())
Next behavior

' svcDesc is a ServiceDescription.
svcDesc = serviceHost.Description
Dim configName As String = svcDesc.ConfigurationName
Console.WriteLine("Configuration name: {0}", configName)

' Iterate through the endpoints contained in the ServiceDescription
Dim sec As ServiceEndpointCollection = svcDesc.Endpoints
For Each se As ServiceEndpoint In sec
    Console.WriteLine("Endpoint:")
    Console.WriteLine(Constants.vbTab & "Address: {0}", se.Address.ToString())
    Console.WriteLine(Constants.vbTab & "Binding: {0}", se.Binding.ToString())
    Console.WriteLine(Constants.vbTab & "Contract: {0}", se.Contract.ToString())
    Dim behaviors As KeyedByTypeCollection(Of IEndpointBehavior) = se.Behaviors
    For Each behavior As IEndpointBehavior In behaviors
        Console.WriteLine("Behavior: {0}", CType(behavior, Object).ToString())
    Next behavior
Next se

Dim name = svcDesc.Name
Console.WriteLine("Service Description name: {0}", name)

Dim namespc = svcDesc.Namespace
Console.WriteLine("Service Description namespace: {0}", namespc)

Dim serviceType As Type = svcDesc.ServiceType
Console.WriteLine("Service Type: {0}", serviceType.ToString())

' Instantiate a service description specifying a service object
' Note: Endpoints collection and other properties will be null since 
' we have not specified them
Dim svcObj As New CalculatorService()
Dim sd3 As ServiceDescription = ServiceDescription.GetService(svcObj)
Dim serviceName = sd3.Name
Console.WriteLine("Service name: {0}", serviceName)

Комментарии

Сведения, ServiceDescription содержащиеся в компоненте, используются системой Windows Communication Foundation (WCF) для создания компонентов времени выполнения для службы.The information contained in the ServiceDescription is used by the Windows Communication Foundation (WCF) system to building the run-time components for the service.

Используйте этот метод при добавлении пользовательских поведений для расширения возможностей ServiceHost.Use this method when adding custom behaviors to extend ServiceHost. Чтобы сделать это программным методом, необходимо добавить (Add(T)) пользовательское поведение службы к поведениям Behaviors перед вызовом метода Open для объекта ServiceHost.Programmatically, you must Add(T) the custom service behavior to the Behaviors prior to when you call the Open method on the ServiceHost object.

Методы GetService(Object) ServiceHostBase и GetService(Type) можно использовать для отражения поведения с помощью модели программирования Windows Communication Foundation (WCF) при замене собственным механизмом размещения.The GetService(Object) and GetService(Type) methods are available to reflect on behaviors using the Windows Communication Foundation (WCF) programming model when replacing ServiceHostBase with you own hosting mechanism.

Экспорт метаданных о конечной точке службы выполняется путем передачи объекта ServiceEndpoint в качестве параметра в метод ExportEndpoint(ServiceEndpoint).Export metadata about a service endpoint by passing ServiceEndpoint as a parameter to ExportEndpoint(ServiceEndpoint). После вызова этого метода или одного из других методов экспорта, предоставленных объектом WsdlExporter, используйте свойство GeneratedWsdlDocuments, чтобы вернуть коллекцию объектов ServiceDescription.After calling this method, or one of the other export methods provided by WsdlExporter, use the GeneratedWsdlDocuments property to return the collection of ServiceDescription objects.

Конструкторы

ServiceDescription()

Инициализирует новый экземпляр класса ServiceDescription.Initializes a new instance of the ServiceDescription class.

ServiceDescription(IEnumerable<ServiceEndpoint>)

Инициализирует новый экземпляр класса ServiceDescription из указанного перечисления конечных точек службы.Initializes a new instance of the ServiceDescription class from a specified enumeration of service endpoints.

Свойства

Behaviors

Возвращает поведения, связанные с этой службой.Gets the behaviors associated with the service.

ConfigurationName

Возвращает или задает имя элемента конфигурации <service>.Gets or sets the name of the <service> configuration element.

Endpoints

Возвращает коллекцию конечных точек из описания службы.Gets the collection of endpoints from the service description.

Name

Возвращает или задает имя службы.Gets or sets the name of the service.

Namespace

Возвращает или задает пространство имен для службы.Gets or sets the namespace for the service.

ServiceType

Возвращает тип службы.Gets the type of the service.

Методы

Equals(Object)

Определяет, равен ли заданный объект текущему объекту.Determines whether the specified object is equal to the current object.

(Унаследовано от Object)
GetHashCode()

Служит хэш-функцией по умолчанию.Serves as the default hash function.

(Унаследовано от Object)
GetService(Object)

Возвращает описание службы, инициализированное с помощью указанного объекта службы.Returns a service description initialized with a specified service object.

GetService(Type)

Возвращает описание службы, инициализированное с помощью указанного типа службы.Returns a service description initialized with a specified service type.

GetType()

Возвращает объект Type для текущего экземпляра.Gets the Type of the current instance.

(Унаследовано от Object)
MemberwiseClone()

Создает неполную копию текущего объекта Object.Creates a shallow copy of the current Object.

(Унаследовано от Object)
ToString()

Возвращает строку, представляющую текущий объект.Returns a string that represents the current object.

(Унаследовано от Object)

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