Создание служб, поддерживающих взаимодействие с базовым профилем WS-I 1.1
Для настройки конечной точки службы WCF таким образом, чтобы она могла взаимодействовать с клиентами веб-службы ASP.NET, необходимо:
использовать в качестве типа привязки для конечной точки службы тип System.ServiceModel.BasicHttpBinding;
не использовать функции обратного вызова и сеансового контракта и не управлять поведением транзакций на конечной точке службы.
В привязке можно дополнительно включить поддержку протокола HTTPS и проверку подлинности клиента на транспортном уровне.
Следующие функции класса BasicHttpBinding требуют функциональность, выходящую за рамки спецификации WS-I Basic Profile, версия 1.1.
Кодирование сообщения подсистемы оптимизации передачи сообщений MTOM управляется свойством System.ServiceModel.BasicHttpBinding.MessageEncoding. Не изменяйте значение этого свойства по умолчанию — System.ServiceModel.WSMessageEncoding.Text (не использовать MTOM).
Безопасность сообщения управляется значением System.ServiceModel.BasicHttpBinding.Security и обеспечивает поддержку WS-Security, совместимую с основным профилем безопасности WS-I версии 1.0. Не изменяйте значение этого свойства по умолчанию — System.ServiceModel.SecurityMode.Transport (не использовать WS-Security).
Чтобы сделать метаданные для службы WCF доступными для ASP.NET, используйте инструменты создания клиента веб-служб: Web Services Description Language Tool (Wsdl.exe), Web Services Discovery Tool (Disco.exe) и функцию Add Web Reference в среде Visual Studio. Необходимо включить публикацию метаданных. Дополнительные сведения см. в разделе Публикация конечных точек метаданных.
Пример
Описание
В следующем примере кода показано, как добавить конечную точку WCF, совместимую с клиентами веб-службы ASP.NET, в код или в файлы конфигурации.
Код
Imports System
Imports System.Collections.Generic
Imports System.Text
Imports System.ServiceModel
Imports System.ServiceModel.Description
<ServiceContract()> _
Public Interface IEcho
<OperationContract()> _
Function Echo(ByVal s As String) As String
End Interface
Public Class MyService
Implements IEcho
Public Function Echo(ByVal s As String) As String Implements IEcho.Echo
Return s
End Function
End Class
Friend Class Program
Shared Sub Main(ByVal args() As String)
Dim baseAddress = "https://localhost:8080/wcfselfhost/"
Dim host As New ServiceHost(GetType(MyService), _
New Uri(baseAddress))
' Add a service endpoint using the created binding
With host
.AddServiceEndpoint(GetType(IEcho), _
New BasicHttpBinding(), _
"echo1")
.Open()
Console.WriteLine("Service listening on {0} . . .", _
baseAddress)
Console.ReadLine()
.Close()
End With
End Sub
End Class
using System;
using System.Collections.Generic;
using System.Text;
using System.ServiceModel;
using System.ServiceModel.Description;
[ServiceContract]
public interface IEcho
{
[OperationContract]
string Echo(string s);
}
public class MyService : IEcho
{
public string Echo(string s)
{
return s;
}
}
class Program
{
static void Main(string[] args)
{
string baseAddress = "https://localhost:8080/wcfselfhost/";
ServiceHost host = new ServiceHost(typeof(MyService), new Uri(baseAddress));
// Create a BasicHttpBinding instance
BasicHttpBinding binding = new BasicHttpBinding();
// Add a service endpoint using the created binding
host.AddServiceEndpoint(typeof(IEcho), binding, "echo1");
host.Open();
Console.WriteLine("Service listening on {0} . . .", baseAddress);
Console.ReadLine();
host.Close();
}
}
<configuration>
<system.serviceModel>
<services>
<service name="MyService" behaviorConfiguration="HttpGetMetadata">
<endpoint address="echo2" contract="IEcho" binding="basicHttpBinding" />
</service>
</services>
<behaviors>
<serviceBehaviors>
<behavior name="HttpGetMetadata">
<serviceMetadata httpGetEnabled="true" />
</behavior>
</serviceBehaviors>
</behaviors>
</system.serviceModel>
</configuration>