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"
첨부한 파일은 테스트가 바로 가능한 프로젝트 소스 코드를 포함하고 있습니다. 
[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]