다음을 통해 공유


방법: 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.SecurityTransport로 설정해야 합니다.

WCF 서비스 메타데이터를 ASP.NET 웹 서비스 프록시 생성 도구로 사용하려면(즉, Web Services Description Language Tool(Wsdl.exe), Web Services Discovery Tool(Disco.exe), Visual Studio에 웹 참조 기능 추가) HTTP/GET 메타데이터 엔드포인트를 노출해야 합니다.

코드에 엔드포인트 추가

  1. BasicHttpBinding 인스턴스를 만듭니다.

  2. 바인딩의 보안 모드를 Transport로 설정하여 이 서비스 엔드포인트 바인딩에 대한 전송 보안을 선택적으로 사용할 수 있습니다. 자세한 내용은 전송 보안을 참조하세요.

  3. 방금 만든 바인딩 인스턴스를 사용하여 새 애플리케이션 엔드포인트를 서비스 호스트에 추가합니다. 코드에서 서비스 엔드포인트를 추가하는 방법에 대한 자세한 내용은 방법: 코드에서 서비스 엔드포인트 만들기를 참조하세요.

  4. 서비스에 대해 HTTP/GET 메타데이터 엔드포인트를 사용합니다. 자세한 내용은 방법: 서비스를 사용 하 여 코드에 대 한 메타 데이터 게시를 참조하세요.

구성 파일에 엔드포인트 추가

  1. BasicHttpBinding 바인딩 구성을 만듭니다. 자세한 내용은 방법: 구성에서 서비스 바인딩 지정을 참조하세요.

  2. 바인딩의 보안 모드를 Transport로 설정하여 이 서비스 엔드포인트 바인딩 구성에 대한 전송 보안을 선택적으로 사용할 수 있습니다. 자세한 내용은 전송 보안을 참조하세요.

  3. 방금 만든 바인딩 구성을 사용하여 서비스에 대한 새 애플리케이션 엔드포인트를 구성합니다. 구성 파일에 서비스 엔드포인트를 추가하는 방법에 대한 자세한 내용은 방법: 구성에서 서비스 엔드포인트 만들기를 참조하세요.

  4. 서비스에 대해 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>

참고 항목