방법: ASP.NET 웹 서비스 클라이언트와 상호 운용하도록 WCF 서비스 구성
ASP.NET 웹 서비스 클라이언트와 상호 운용 가능하도록 WCF(Windows Communication Foundation) 서비스 엔드포인트를 구성하려면 System.ServiceModel.BasicHttpBinding 형식을 서비스 엔드포인트의 바인딩 형식으로 사용합니다.
바인딩에서 HTTPS 및 전송 수준 클라이언트 인증에 대한 지원을 선택적으로 사용할 수 있습니다. ASP.NET 웹 서비스 클라이언트는 MTOM 메시지 인코딩을 지원하지 않기 때문에 BasicHttpBinding.MessageEncoding 속성을 기본값인 WSMessageEncoding.Text(으)로 두어야 합니다. ASP.NET 웹 서비스 클라이언트는 WS-Security를 지원하지 않기 때문에 BasicHttpBinding.Security를 Transport로 설정해야 합니다.
WCF 서비스 메타데이터를 ASP.NET 웹 서비스 프록시 생성 도구로 사용하려면(즉, Web Services Description Language Tool(Wsdl.exe), Web Services Discovery Tool(Disco.exe), Visual Studio에 웹 참조 기능 추가) HTTP/GET 메타데이터 엔드포인트를 노출해야 합니다.
코드에 엔드포인트 추가
새 BasicHttpBinding 인스턴스를 만듭니다.
바인딩의 보안 모드를 Transport로 설정하여 이 서비스 엔드포인트 바인딩에 대한 전송 보안을 선택적으로 사용할 수 있습니다. 자세한 내용은 전송 보안을 참조하세요.
방금 만든 바인딩 인스턴스를 사용하여 새 애플리케이션 엔드포인트를 서비스 호스트에 추가합니다. 코드에서 서비스 엔드포인트를 추가하는 방법에 대한 자세한 내용은 방법: 코드에서 서비스 엔드포인트 만들기를 참조하세요.
서비스에 대해 HTTP/GET 메타데이터 엔드포인트를 사용합니다. 자세한 내용은 방법: 서비스를 사용 하 여 코드에 대 한 메타 데이터 게시를 참조하세요.
구성 파일에 엔드포인트 추가
새 BasicHttpBinding 바인딩 구성을 만듭니다. 자세한 내용은 방법: 구성에서 서비스 바인딩 지정을 참조하세요.
바인딩의 보안 모드를 Transport로 설정하여 이 서비스 엔드포인트 바인딩 구성에 대한 전송 보안을 선택적으로 사용할 수 있습니다. 자세한 내용은 전송 보안을 참조하세요.
방금 만든 바인딩 구성을 사용하여 서비스에 대한 새 애플리케이션 엔드포인트를 구성합니다. 구성 파일에 서비스 엔드포인트를 추가하는 방법에 대한 자세한 내용은 방법: 구성에서 서비스 엔드포인트 만들기를 참조하세요.
서비스에 대해 HTTP/GET 메타데이터 엔드포인트를 사용합니다. 자세한 내용은 방법: 구성 파일을 사용하여 서비스의 메타데이터 게시를 참조하세요.
예시
다음 예제 코드에서는 ASP.NET 웹 서비스 클라이언트와 호환되는 WCF 엔드포인트를 코드 또는 구성 파일에 추가하는 방법을 보여 줍니다.
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 = "http://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();
}
}
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 = "http://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
<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>