Microsoft MVP성태의 닷넷 이야기
.NET Framework: 1011. C# - OWIN Web API 예제 프로젝트 [링크 복사], [링크+제목 복사],
조회: 20022
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)
(시리즈 글이 3개 있습니다.)
기타: 72. 과거의 용어 설명 - OWIN
; https://www.sysnet.pe.kr/2/0/11596

.NET Framework: 998. C# - OWIN 예제 프로젝트 만들기
; https://www.sysnet.pe.kr/2/0/12479

.NET Framework: 1011. C# - OWIN Web API 예제 프로젝트
; https://www.sysnet.pe.kr/2/0/12497




C# - OWIN Web API 예제 프로젝트

지난번에 만들어 둔 OWIN 예제에,

C# - OWIN 예제 프로젝트 만들기
; https://www.sysnet.pe.kr/2/0/12479

아래의 글을 따라,

Use OWIN to Self-Host ASP.NET Web API
; https://docs.microsoft.com/en-us/aspnet/web-api/overview/hosting-aspnet-web-api/use-owin-to-self-host-web-api

Web API를 추가해 볼 텐데요, 이를 위해 우선 2개의 패키지를 참조 추가해야 합니다.

Install-Package Microsoft.AspNet.WebApi.Core
Install-Package Microsoft.AspNet.WebApi.Owin

그런 다음 기존 소스 코드의 Startup.Configuration 메서드를 이렇게 변경하고,

// https://github.com/aspnet/samples/blob/master/samples/aspnet/WebApi/OwinSelfhostSample/OwinSelfhostSample/Startup.cs
using Microsoft.Owin;
using Owin;
using System;
using System.Threading.Tasks;
using System.Web.Http;

[assembly: OwinStartup(typeof(OwinWebApp.Startup))]

namespace OwinWebApp
{
    public class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            HttpConfiguration config = new HttpConfiguration();

            config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{id}",
                defaults: new { id = RouteParameter.Optional }
                );

            app.UseWebApi(config);

            app.Run(context =>
            {
                context.Response.ContentType = "text/plain";
                return context.Response.WriteAsync("Hello, world.");
            });
        }
    }
}

마지막으로 전형적인 Web API Controller 코드를 구현하면 마무리가 됩니다.

// https://github.com/aspnet/samples/blob/master/samples/aspnet/WebApi/OwinSelfhostSample/OwinSelfhostSample/ValuesController.cs
using System.Collections.Generic;
using System.Web.Http;

namespace OwinWebApp
{
    public class ValuesController : ApiController
    {
        // GET api/values 
        public IEnumerable<string> Get()
        {
            return new string[] { "value1", "value2" };
        }

        // GET api/values/5 
        public string Get(int id)
        {
            return "value";
        }

        // POST api/values 
        public void Post([FromBody] string value)
        {
        }

        // PUT api/values/5 
        public void Put(int id, [FromBody] string value)
        {
        }

        // DELETE api/values/5 
        public void Delete(int id)
        {
        }
    }
}

이후, "http://localhost:[port]/api/values"로 접근하면 ValuesController.Get 메서드가 실행되는 것을 확인할 수 있습니다.




참고로, Controller에 Route 특성을 명시해 라우트 경로를 바꾸고 싶다면,

using System.Collections.Generic;
using System.Web.Http;

namespace OwinWebApp
{
    [Route("services")]
    public class ValuesController : ApiController
    {
        // ...[생략]...
    }
}

Startup.Configuration 메서드에 MapHttpAttributeRoutes 메서드 호출만 더 추가하면 됩니다.

using Microsoft.Owin;
using Owin;
using System;
using System.Threading.Tasks;
using System.Web.Http;

[assembly: OwinStartup(typeof(OwinWebApp.Startup))]

namespace OwinWebApp
{
    public class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            HttpConfiguration config = new HttpConfiguration();

            config.MapHttpAttributeRoutes();

            config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{id}",
                defaults: new { id = RouteParameter.Optional }
                );

            app.UseWebApi(config);
        }
    }
}

그럼, 이제부터는 특성에 지정한 값에 따라 "http://localhost:[port]/api/services"로 접근할 수 있습니다.




마지막으로, OWIN Web API도 비동기 프레임워크이기 때문에 async/await을 사용할 수 있습니다.

using System.Collections.Generic;
using System.Web.Http;

namespace OwinWebApp
{
    public class ValuesController : ApiController
    {
        public async Task<IEnumerable<string>> Get()
        {
            await Task.Delay(500);
            return new string[] { "value1", "value2" };
        }
        
        // ...[생략]...
    }
}

(첨부 파일은 이 글의 예제 코드를 포함합니다.)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/2/2021]

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

비밀번호

댓글 작성자
 



2021-03-02 03시21분
How to write OWIN middleware in 5 different steps
; https://benfoster.io/blog/how-to-write-owin-middleware-in-5-different-steps/
정성태

1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13141정성태10/17/202216357.NET Framework: 2058. [in,out] 배열을 C#에서 C/C++로 넘기는 방법 - 세 번째 이야기파일 다운로드1
13139정성태10/9/202213932.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법파일 다운로드1
13138정성태10/8/202216544.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]
13137정성태10/8/202214546.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
13136정성태10/7/202214843.NET Framework: 2054. .NET Core/5+ SDK 설치 없이 dotnet-dump 사용하는 방법
13135정성태10/5/202215435.NET Framework: 2053. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프를 분석하는 방법 - 두 번째 이야기 [1]
13131정성태10/3/202217431.NET Framework: 2052. C# - Windows Forms의 데이터 바인딩 지원(DataBinding, DataSource) [2]파일 다운로드1
13130정성태9/28/202213345.NET Framework: 2051. .NET Core/5+ - 에러 로깅을 위한 Middleware가 동작하지 않는 경우파일 다운로드1
13129정성태9/27/202214005.NET Framework: 2050. .NET Core를 IIS에서 호스팅하는 경우 .NET Framework CLR이 함께 로드되는 환경
13126정성태9/15/202215657.NET Framework: 2049. C# 11 - 정적 메서드에 대한 delegate 처리 시 cache 적용
13125정성태9/14/202216010.NET Framework: 2048. C# 11 - 구조체 필드의 자동 초기화(auto-default structs)
13124정성태9/13/202215876.NET Framework: 2047. Golang, Python, C#에서의 CRC32 사용
13123정성태9/8/202215906.NET Framework: 2046. C# 11 - 멤버(속성/필드)에 지정할 수 있는 required 예약어 추가
13122정성태8/26/202216335.NET Framework: 2045. C# 11 - 메서드 매개 변수에 대한 nameof 지원
13119정성태8/18/202215480.NET Framework: 2044. .NET Core/5+ 프로젝트에서 참조 DLL이 보관된 공통 디렉터리를 지정하는 방법
13118정성태8/18/202212900.NET Framework: 2043. WPF Color의 기본 색 영역은 (sRGB가 아닌) scRGB [2]
13117정성태8/17/202216724.NET Framework: 2042. C# 11 - 파일 범위 내에서 유효한 타입 정의 (File-local types)파일 다운로드1
13116정성태8/4/202217096.NET Framework: 2041. C# - Socket.Close 시 Socket.Receive 메서드에서 예외가 발생하는 문제파일 다운로드1
13115정성태8/3/202217735.NET Framework: 2040. C# - ValueTask와 Task의 성능 비교 [1]파일 다운로드1
13114정성태8/2/202217550.NET Framework: 2039. C# - Task와 비교해 본 ValueTask 사용법파일 다운로드1
13113정성태7/31/202217087.NET Framework: 2038. C# 11 - Span 타입에 대한 패턴 매칭 (Pattern matching on ReadOnlySpan<char>)
13112정성태7/30/202217954.NET Framework: 2037. C# 11 - 목록 패턴(List patterns) [1]파일 다운로드1
13111정성태7/29/202217382.NET Framework: 2036. C# 11 - IntPtr/UIntPtr과 nint/nuint의 통합파일 다운로드1
13110정성태7/27/202216990.NET Framework: 2035. C# 11 - 새로운 연산자 ">>>" (Unsigned Right Shift)파일 다운로드1
13105정성태7/23/202216986.NET Framework: 2034. .NET Core/5+ 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 - 두 번째 이야기 [1]
13102정성태7/19/202215758.NET Framework: 2033. .NET Core/5+에서는 구할 수 없는 HttpRuntime.AppDomainAppId
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...