Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 4개 있습니다.)
(시리즈 글이 4개 있습니다.)
.NET Framework: 1010. .NET Core 콘솔 프로젝트에서 Kestrel 호스팅 방법
; https://www.sysnet.pe.kr/2/0/12496

.NET Framework: 1012. .NET Core Kestrel 호스팅 - 비주얼 스튜디오의 Kestrel/IIS Express 프로파일 설정
; https://www.sysnet.pe.kr/2/0/12498

.NET Framework: 1013. .NET Core Kestrel 호스팅 - 포트 변경, non-localhost 접속 지원 및 https 등의 설정 변경
; https://www.sysnet.pe.kr/2/0/12499

.NET Framework: 1018. .NET Core Kestrel 호스팅 - Web API 추가
; https://www.sysnet.pe.kr/2/0/12505




.NET Core Kestrel 호스팅 - 포트 변경, non-localhost 접속 지원 및 https 등의 설정 변경

지난 글에서,

.NET Core 콘솔 프로젝트에서 Kestrel 호스팅 방법
; https://www.sysnet.pe.kr/2/0/12496

기본적인 Kestrel 호스팅을 다뤘는데요. 이번에는, 해당 예제로부터 살을 좀 덧붙여보겠습니다. (제목에 충실하기 위해, applicationhost.config의 내용을 바꿔야 하는 IIS Express 호스팅 환경은 다루지 않습니다.)

우선, 위의 글에 실린 기본 예제로 실행하면 http, https 호스팅이 가능합니다. 그리고, 서버 소켓이 localhost로만 바인딩되어 있기 때문에 IP를 통해 접속을 못한다는, 즉 외부에서 접속할 수 없다는 문제가 있는데요. 이런 제약은 다음의 ConfigureKestrel 메서드 호출로 해결할 수 있고 이에 대해서는 전에도 다룬 적이 있습니다.

로컬 PC에서 개발 중인 ASP.NET Core 웹 응용 프로그램을 다른 PC에서도 접근하는 방법
; https://www.sysnet.pe.kr/2/0/12081

// 비주얼 스튜디오의 경우 "프로파일" 설정을 "IIS Express"가 아닌 "ConsoleApp1"로 바꾸고 실행
// .NET Core 3.1

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder =>
        {
            webBuilder.ConfigureKestrel(options =>
            {
                options.ListenAnyIP(16000);
            });

            webBuilder.UseStartup<Startup>();
        });

/* 출력 결과
      Overriding address(es) 'https://localhost:5001, http://localhost:5000'. Binding to endpoints defined in UseKestrel() instead.
info: Microsoft.Hosting.Lifetime[0]
      Now listening on: http://[::]:16000
...[생략]...
*/

위와 같이 바꾸면, 출력 결과에도 나오지만 Kestrel 기본 호스팅 코드가 설정한 (또는 비주얼 스튜디오의 경우 launchSettings.json을 이용해 재정의 가능한) http/5000, https/5001에 대한 설정은 이제 무시하고 http/16000으로만 서비스를 합니다. 따라서, https 서비스도 함께 하고 싶다면 이에 대한 것도 추가를 해야 합니다.

Configure endpoints for the ASP.NET Core Kestrel web server
; https://learn.microsoft.com/en-us/aspnet/core/fundamentals/servers/kestrel/endpoints

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder =>
        {
            webBuilder.ConfigureKestrel(options =>
            {
                options.ListenAnyIP(16000);
                options.ListenAnyIP(16001, (httpsOpt) =>
                {
                    httpsOpt.UseHttps();
                });
            });

            webBuilder.UseStartup<Startup>();
        });

(https와 관련한 인증서 설정은 ListenOptions.UseHttps을 참고하세요.)

또한 https 접속만 가능하게 하려는 경우 http로부터의 우회 설정등이 필요할 텐데 이에 대해서는 다음의 글을 참고하시고,

Enforce HTTPS in ASP.NET Core
; https://learn.microsoft.com/en-us/aspnet/core/security/enforcing-ssl

이 글에서 설명한 것 외에 가능한 options 설정들은 아래의 글을 참고하시면 됩니다. ^^

Configure options for the ASP.NET Core Kestrel web server
; https://learn.microsoft.com/en-us/aspnet/core/fundamentals/servers/kestrel/options




다시 말하지만, 이 설정들은 모두 Kestrel 호스팅 환경에서만 유효하고 나중에 실 서비스를 IIS에 얹으면 아무런 효과가 없습니다.

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




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/28/2023]

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

비밀번호

댓글 작성자
 



2022-01-27 09시51분
.NET 6에서 Kestrel 포트를 설정하는 몇가지(너무 많은?) 방법 | Bryan Hogan
; https://forum.dotnetdev.kr/t/net-6-kestrel-bryan-hogan/2681
정성태

... 46  47  48  [49]  50  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12746정성태7/31/202124003개발 환경 구성: 588. 네트워크 장비 환경을 시뮬레이션하는 Packet Tracer 프로그램 소개
12745정성태7/31/202116454개발 환경 구성: 587. Azure Active Directory - tenant의 관리자 계정 로그인 방법
12744정성태7/30/202116524개발 환경 구성: 586. Azure Active Directory에 연결된 App 목록을 확인하는 방법?
12743정성태7/30/202118085.NET Framework: 1083. Azure Active Directory - 외부 Token Cache 저장소를 사용하는 방법파일 다운로드1
12742정성태7/30/202115764개발 환경 구성: 585. Azure AD 인증을 위한 사용자 인증 유형
12741정성태7/29/202117466.NET Framework: 1082. Azure Active Directory - Microsoft Graph API 호출 방법파일 다운로드1
12740정성태7/29/202116059오류 유형: 747. SharePoint - InvalidOperationException 0x80131509
12739정성태7/28/202116335오류 유형: 746. Azure Active Directory - IDW10106: The 'ClientId' option must be provided.
12738정성태7/28/202117554오류 유형: 745. Azure Active Directory - Client credential flows must have a scope value with /.default suffixed to the resource identifier (application ID URI).
12737정성태7/28/202116613오류 유형: 744. Azure Active Directory - The resource principal named api://...[client_id]... was not found in the tenant
12736정성태7/28/202116914오류 유형: 743. Active Azure Directory에서 "API permissions"의 권한 설정이 "Not granted for ..."로 나오는 문제
12735정성태7/27/202115891.NET Framework: 1081. C# - Azure AD 인증을 지원하는 데스크톱 애플리케이션 예제(Windows Forms) [2]파일 다운로드1
12734정성태7/26/202132773스크립트: 20. 특정 단어로 시작하거나/끝나는 문자열을 포함/제외하는 정규 표현식 - Look-around
12733정성태7/23/202121900.NET Framework: 1081. Self-Contained/SingleFile 유형의 .NET Core/5+ 실행 파일을 임베딩한다면? [1]파일 다운로드2
12732정성태7/23/202114407오류 유형: 742. SharePoint - The super user account utilized by the cache is not configured.
12731정성태7/23/202116433개발 환경 구성: 584. Add Internal URLs 화면에서 "Save" 버튼이 비활성화 된 경우
12730정성태7/23/202118278개발 환경 구성: 583. Visual Studio Code - Go 코드에서 입력을 받는 경우
12729정성태7/22/202116314.NET Framework: 1080. xUnit 단위 테스트에 메서드/클래스 수준의 문맥 제공 - Fixture
12728정성태7/22/202116926.NET Framework: 1079. MSTestv2 단위 테스트에 메서드/클래스/어셈블리 수준의 문맥 제공
12727정성태7/21/202118032.NET Framework: 1078. C# 단위 테스트 - MSTestv2/NUnit의 Assert.Inconclusive 사용법(?) [1]
12726정성태7/21/202117505VS.NET IDE: 169. 비주얼 스튜디오 - 단위 테스트 선택 시 MSTestv2 외의 xUnit, NUnit 사용법 [1]
12725정성태7/21/202116151오류 유형: 741. Failed to find the "go" binary in either GOROOT() or PATH
12724정성태7/21/202119137개발 환경 구성: 582. 윈도우 환경에서 Visual Studio Code + Go (Zip) 개발 환경 [1]
12723정성태7/21/202115223오류 유형: 740. SharePoint - Alternate access mappings have not been configured 경고
12722정성태7/20/202115321오류 유형: 739. MSVCR110.dll이 없어 exe 실행이 안 되는 경우
12721정성태7/20/202121057오류 유형: 738. The trust relationship between this workstation and the primary domain failed. - 세 번째 이야기
... 46  47  48  [49]  50  51  52  53  54  55  56  57  58  59  60  ...