다음을 통해 공유


방법: ASP.NET 웹 서비스 클라이언트와 상호 운용하도록 WCF 서비스 구성

WCF(Windows Communication Foundation) 서비스 엔드포인트를 ASP.NET 웹 서비스 클라이언트와 상호 운용할 수 있도록 구성하려면 해당 형식을 서비스 엔드포인트에 대한 바인딩 형식으로 사용합니다 System.ServiceModel.BasicHttpBinding .

필요에 따라 바인딩에서 HTTPS 및 전송 수준 클라이언트 인증에 대한 지원을 사용하도록 설정할 수 있습니다. ASP.NET 웹 서비스 클라이언트는 MTOM 메시지 인코딩을 지원하지 않으므로 BasicHttpBinding.MessageEncoding 속성은 기본값인 WSMessageEncoding.Text그대로 두어야 합니다. ASP.NET 웹 서비스 클라이언트는 WS-Security를 지원하지 않으므로 BasicHttpBinding.Security 설정 Transport해야 합니다.

WCF 서비스에 대한 메타데이터를 ASP.NET 웹 서비스 프록시 생성 도구(즉, 웹 서비스 설명 언어 도구(Wsdl.exe), 웹 서비스 검색 도구(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 {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>

참고하십시오