Microsoft MVP성태의 닷넷 이야기
.NET Framework: 171. WCF - webHttpBinding 구현 예제 [링크 복사], [링크+제목 복사],
조회: 29808
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)
(시리즈 글이 4개 있습니다.)
.NET Framework: 171. WCF - webHttpBinding 구현 예제
; https://www.sysnet.pe.kr/2/0/833

.NET Framework: 172. WCF - webHttpBinding 윈도우 인증 구현 예제
; https://www.sysnet.pe.kr/2/0/834

.NET Framework: 173. WCF - webHttpBinding + IIS 6.0 윈도우 인증 구현 예제
; https://www.sysnet.pe.kr/2/0/835

.NET Framework: 175. WCF - webHttpBinding + PUT 메서드 구현
; https://www.sysnet.pe.kr/2/0/850





WCF - webHttpBinding 구현 예제


아래의 질문 덕분에 WCF의 webHttpBinding 예제를 구성해 보았습니다.

How to support Basic + Windows authentication mode in WCF(RESTful service) 
; https://www.sysnet.pe.kr/3/0/857

사실, WCF가 워낙 잘 추상화를 해놓아서 별로 할 것이 없는데다 아래와 같이 이미 영문 블로그에서 친절하게 소개해 놓았기 때문에 굳이 쓸 이유까지도 없어보이지만....

WCF - Using WebHttpBinding for REST services 
; https://asp-blogs.azurewebsites.net/kiyoshi/wcf-using-webhttpbinding-for-rest-services

그래도 직접 해보면 또 다른 묘미가 있기 때문에. ^^

일단, Contract 먼저 보면,

[ServiceContract(Namespace = "http://www.wcftest.com/")]
public interface IHelloWorld
{
    [WebGet(UriTemplate = "date/{year}/{month}/{day}", ResponseFormat = WebMessageFormat.Xml)]
    [OperationContract]
    string GetDate(string year, string month, string day);
}

라는 식으로 정의하면 되는데, ResponseFormat의 경우 기본값이 Xml이므로 명시할 이유는 없지만 WebMessageFormat.Json으로도 변경할 수 있다는 가능성을 보여주기 위해 그대로 두었습니다. 구현 부분은 아래와 같이 일반 클래스 구현과 다른 점이 없습니다.

[ServiceBehavior]
public class CHelloWorld : IHelloWorld
{
    public string GetDate(string year, string month, string day)
    {
        return new DateTime(Convert.ToInt32(year), 
        	Convert.ToInt32(month), Convert.ToInt32(day)).ToShortDateString();
    }
}

서버 측은, 지저분한 web.config이 마음에 들지 않으니 다음과 같이 코드만으로 할 수 있고,

string baseAddress = "http://" + Environment.MachineName + ":9091/HelloService";

using (ServiceHost serviceHost = new ServiceHost(typeof(CHelloWorld), 
                                new Uri(baseAddress)))
{
    ServiceEndpoint endpoint = 
        serviceHost.AddServiceEndpoint(typeof(IHelloWorld), new WebHttpBinding(), "");
    endpoint.Behaviors.Add(new WebHttpBehavior());
    serviceHost.Open();

    Console.WriteLine("Press any key to exit...");
    Console.ReadLine();
}

클라이언트 측 코드 역시 web.config을 간결하게 하도록 다음과 같이 코드를 구성할 수 있습니다.

using (ChannelFactory<IHelloWorld> factory = 
        new ChannelFactory<IHelloWorld>(new WebHttpBinding(),
        new EndpointAddress(baseAddress)))
{
    factory.Endpoint.Behaviors.Add(new WebHttpBehavior());
    IHelloWorld proxy = factory.CreateChannel();
    Console.WriteLine("Result of Get operation: {0}", proxy.GetDate("1990", "05", "01"));
}

이제 F5 키를 눌러서 실행 결과 확인!




REST 서비스의 재미있는 점을 짚고 넘어가야겠지요. 복잡한 Soap Envelope 구성 없이 요청/반환 구조가 URL에 의해서 이루어질 수 있는데요.

[WebGet(UriTemplate = "date/{year}/{month}/{day}", ResponseFormat = WebMessageFormat.Xml)]
[OperationContract]
string GetDate(string year, string month, string day);

위의 UriTemplate 지정으로 GetDate 웹 메서드를 호출하기 위해 다음과 같은 식으로 요청을 보내는 것이 가능합니다.

http://127.0.0.1:9091/HelloService/date/1995/10/10

오호... 마치 MVC의 URL Routing하는 것과 비슷한 구조를 제공해 주고 있습니다. 실제로 위와 같은 URL로 웹 브라우저의 주소 표시줄에 입력하고 실행하면 다음과 같은 결과를 얻을 수 있습니다.

ResponseFormat = WebMessageFormat.Xml인 경우,
<string xmlns="http://schemas.microsoft.com/2003/10/Serialization/">1995-10-10</string> 

ResponseFormat = WebMessageFormat.Json인 경우,
"1995-10-10"

첨부한 파일은 테스트가 바로 가능한 프로젝트 소스 코드를 포함하고 있습니다.



[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/24/2025]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2011-03-23 09시54분
정성태

... 31  32  33  34  [35]  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13159정성태11/10/202220900.NET Framework: 2066. C# - PublishSingleFile과 관련된 옵션 [3]
13158정성태11/9/202216603오류 유형: 826. Workload definition 'wasm-tools' in manifest 'microsoft.net.workload.mono.toolchain' [...] conflicts with manifest 'microsoft.net.workload.mono.toolchain.net7'
13157정성태11/8/202217734.NET Framework: 2065. C# - Mutex의 비동기 버전파일 다운로드1
13156정성태11/7/202221097.NET Framework: 2064. C# - Mutex와 Semaphore/SemaphoreSlim 차이점파일 다운로드1
13155정성태11/4/202218203디버깅 기술: 183. TCP 동시 접속 (연결이 아닌) 시도를 1개로 제한한 서버
13154정성태11/3/202219376.NET Framework: 2063. .NET 5+부터 지원되는 GC.GetGCMemoryInfo파일 다운로드1
13153정성태11/2/202220032.NET Framework: 2062. C# - 코드로 재현하는 소켓 상태(SYN_SENT, SYN_RECV)
13152정성태11/1/202219096.NET Framework: 2061. ASP.NET Core - DI로 추가한 클래스의 초기화 방법 [1]
13151정성태10/31/202218373C/C++: 161. Windows 11 환경에서 raw socket 테스트하는 방법파일 다운로드1
13150정성태10/30/202215781C/C++: 160. Visual Studio 2022로 빌드한 C++ 프로그램을 위한 다른 PC에서 실행하는 방법
13149정성태10/27/202216679오류 유형: 825. C# - CLR ETW 이벤트 수신이 GCHeapStats_V1/V2에 대해 안 되는 문제파일 다운로드1
13148정성태10/26/202218529오류 유형: 824. msbuild 에러 - error NETSDK1005: Assets file '...\project.assets.json' doesn't have a target for 'net5.0'. Ensure that restore has run and that you have included 'net5.0' in the TargetFramew
13147정성태10/25/202217416오류 유형: 823. Visual Studio 2022 - Unable to attach to CoreCLR. The debugger's protocol is incompatible with the debuggee.
13146정성태10/24/202219166.NET Framework: 2060. C# - Java의 Xmx와 유사한 힙 메모리 최댓값 제어 옵션 HeapHardLimit
13145정성태10/21/202218546오류 유형: 822. db2 - Password validation for user db2inst1 failed with rc = -2146500508
13144정성태10/20/202219782.NET Framework: 2059. ClrMD를 이용해 윈도우 환경의 메모리 덤프로부터 닷넷 모듈을 추출하는 방법파일 다운로드1
13143정성태10/19/202220297오류 유형: 821. windbg/sos - Error code - 0x000021BE
13142정성태10/18/202229302도서: 시작하세요! C# 12 프로그래밍
13141정성태10/17/202220187.NET Framework: 2058. [in,out] 배열을 C#에서 C/C++로 넘기는 방법 - 세 번째 이야기파일 다운로드1
13140정성태10/11/202220460C/C++: 159. C/C++ - 리눅스 환경에서 u16string 문자열을 출력하는 방법 [2]
13139정성태10/9/202217328.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법파일 다운로드1
13138정성태10/8/202220460.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]
13137정성태10/8/202219673.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
13136정성태10/7/202218769.NET Framework: 2054. .NET Core/5+ SDK 설치 없이 dotnet-dump 사용하는 방법
13135정성태10/5/202220145.NET Framework: 2053. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프를 분석하는 방법 - 두 번째 이야기 [1]
13134정성태10/4/202215084오류 유형: 820. There is a problem with AMD Radeon RX 5600 XT device. For more information, search for 'graphics device driver error code 31'
... 31  32  33  34  [35]  36  37  38  39  40  41  42  43  44  45  ...