Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

Visual Studio 17.5 (Preview 2) - 포트 터널링을 이용한 웹 응용 프로그램의 외부 접근 허용

2023-02-22: 17.5 버전이 정식으로 릴리스되었습니다.




관련해서 줄줄이 소식이 나오고 있군요. ^^

Use Visual Studio Port Tunneling to handle Twilio Webhooks
; https://www.twilio.com/blog/use-visual-studio-port-tunneling-with-twilio-webhooks

Public preview of dev tunnels in Visual Studio for ASP.NET Core projects 3
; https://devblogs.microsoft.com/visualstudio/public-preview-of-dev-tunnels-in-visual-studio-for-asp-net-core-projects/

Dev tunnels in Visual Studio for ASP.NET Core projects
; https://devblogs.microsoft.com/visualstudio/dev-tunnels-in-visual-studio-for-asp-net-core-projects/

현재 17.5 preview 2에만 포함되었고, 명시적으로 활성화시켜야 하는 옵션(Enable dev tunnels for Web Applications)입니다.

vs_tunnel_1.png

이후 간단하게 Web Application (ASP.NET Core Web App)을 하나 만들고, 프로젝트 시작 유형을 "Dev Tunnels" 메뉴를 이용해 "Create A Tunnel..."을 선택합니다. 그럼 다음과 같이 Microsoft Account 인증과 함께 터널링 관련 정보를 선택하는 창이 뜹니다.

vs_tunnel_2.png

Name은 비주얼 스튜디오 툴바에 위치한 시작 유형 메뉴의 이름으로 제공되는 것이므로 가볍게 입력하시면 됩니다. 그 외, Tunnel Type은 "Temporary"와, "Persistent"가 제공되고, Access 유형은 "Private", "Organizational", "Public"을 선택할 수 있습니다. 이 글에서는 간단하게 다음의 설정으로 생성하겠습니다.

Name: mytunnel
Tunnel Type: Temporary
Access: Public

이제, 기존 Web Application 프로젝트를 F5 키로 시작하면 첫 화면이 터널링된 주소로 접근하는 페이지로 바뀝니다.

vs_tunnel_3.png

"CONTINUE" 버튼을 누르면 이후의 동작 과정은 일반적인 웹 애플리케이션의 실행을 따릅니다. (위의 화면은 개발자 컴퓨터에서 한 번만 뜨고, 이후로는 곧바로 아래의 화면부터 보여줍니다.)

vs_tunnel_4.png

또한, 해당 URL(위의 이미지에서는 "https://7vhxqtlv-5131.asse.devtunnels.ms/")을 다른 컴퓨터, 심지어 외부 네트워크에 있는 컴퓨터에서도 접근할 수 있다는 차이점이 있습니다.

참고로, 프로세스 내의 "VS_TUNNEL_URL"로도 URL 주소가 설정되므로 코드를 통해 알아내는 것도 가능합니다.




사실, 개발자 PC에서 Visual Studio로 실행한 웹 애플리케이션을 다른 PC에서 접근할 수 있는 것이 크게 의미 있는 경우는 거의 없습니다. 단지, 최근 들어 callbacck 유형으로 web hook을 구현해야 하는 경우에는 제법 유용하게 쓸 수 있습니다. 실제로 "Use Visual Studio Port Tunneling to handle Twilio Webhooks" 글은 그런 사례를 보여줍니다.

암튼, 점점 더 개발 환경은 편리해져 가는군요. ^^





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

[연관 글]






[최초 등록일: ]
[최종 수정일: 2/22/2023]

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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13342정성태5/8/20233514.NET Framework: 2115. System.Text.Json의 역직렬화 시 필드/속성 주의
13341정성태5/8/20233336닷넷: 2114. C# 12 - 모든 형식의 별칭(Using aliases for any type)
13340정성태5/8/20233227오류 유형: 857. Microsoft.Data.SqlClient.SqlException - 0x80131904
13339정성태5/6/20233908닷넷: 2113. C# 12 - 기본 생성자(Primary Constructors)
13338정성태5/6/20233485닷넷: 2112. C# 12 - 기본 람다 매개 변수파일 다운로드1
13337정성태5/5/20233882Linux: 59. dockerfile - docker exec로 container에 접속 시 자동으로 실행되는 코드 적용
13336정성태5/4/20233631.NET Framework: 2111. C# - 바이너리 출력 디렉터리와 연관된 csproj 설정
13335정성태4/30/20233760.NET Framework: 2110. C# - FFmpeg.AutoGen 라이브러리를 이용한 기본 프로젝트 구성 - Windows Forms파일 다운로드1
13334정성태4/29/20233519Windows: 250. Win32 C/C++ - Modal 메시지 루프 내에서 SetWindowsHookEx를 이용한 Thread 메시지 처리 방법
13333정성태4/28/20232979Windows: 249. Win32 C/C++ - 대화창 템플릿을 런타임에 코딩해서 사용파일 다운로드1
13332정성태4/27/20233111Windows: 248. Win32 C/C++ - 대화창을 위한 메시지 루프 사용자 정의파일 다운로드1
13331정성태4/27/20233120오류 유형: 856. dockerfile - 구 버전의 .NET Core 이미지 사용 시 apt update 오류
13330정성태4/26/20232781Windows: 247. Win32 C/C++ - CS_GLOBALCLASS 설명
13329정성태4/24/20233078Windows: 246. Win32 C/C++ - 직접 띄운 대화창 템플릿을 위한 Modal 메시지 루프 생성파일 다운로드1
13328정성태4/19/20232691VS.NET IDE: 184. Visual Studio - Fine Code Coverage에서 동작하지 않는 Fake/Shim 테스트
13327정성태4/19/20233116VS.NET IDE: 183. C# - .NET Core/5+ 환경에서 Fakes를 이용한 단위 테스트 방법
13326정성태4/18/20234307.NET Framework: 2109. C# - 닷넷 응용 프로그램에서 SQLite 사용 (System.Data.SQLite) [1]파일 다운로드1
13325정성태4/18/20233756스크립트: 48. 파이썬 - PostgreSQL의 with 문을 사용한 경우 연결 개체 누수
13324정성태4/17/20233566.NET Framework: 2108. C# - Octave의 "save -binary ..."로 생성한 바이너리 파일 분석파일 다운로드1
13323정성태4/16/20233429개발 환경 구성: 677. Octave에서 Excel read/write를 위한 io 패키지 설치
13322정성태4/15/20234084VS.NET IDE: 182. Visual Studio - 32비트로만 빌드된 ActiveX와 작업해야 한다면?
13321정성태4/14/20233102개발 환경 구성: 676. WSL/Linux Octave - Python 스크립트 연동
13320정성태4/13/20233111개발 환경 구성: 675. Windows Octave 8.1.0 - Python 스크립트 연동
13319정성태4/12/20233493개발 환경 구성: 674. WSL 2 환경에서 GNU Octave 설치
13318정성태4/11/20233317개발 환경 구성: 673. JetBrains IDE에서 "Squash Commits..." 메뉴가 비활성화된 경우
13317정성태4/11/20233472오류 유형: 855. WSL 2 Ubuntu 20.04 - error: cannot communicate with server: Post http://localhost/v2/snaps/...
1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...