Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 2개 있습니다.)
.NET Framework: 2091. C# - 웹 사이트가 어떤 버전의 TLS/SSL을 지원하는지 확인하는 방법
; https://www.sysnet.pe.kr/2/0/13237

.NET Framework: 2092. IIS 웹 사이트를 TLS 1.2 또는 TLS 1.3 프로토콜로만 운영하는 방법
; https://www.sysnet.pe.kr/2/0/13238




IIS 웹 사이트를 TLS 1.2 또는 TLS 1.3 프로토콜로만 운영하는 방법

테스트를 위해 VM으로 만들어 둔 Windows 11 운영체제에 openssl로 인증서를 만들어,

openssl을 이용해 인트라넷 IIS 사이트의 SSL 인증서 생성
; https://www.sysnet.pe.kr/2/0/13236

https 통신을 적용한 다음 서버가 지원하는 보안 프로토콜을 확인해 보면,

C# - 웹 사이트가 어떤 버전의 TLS/SSL을 지원하는지 확인하는 방법
; https://www.sysnet.pe.kr/2/0/13237

이런 결과가 나옵니다.

Ssl3(48): Not supported - The underlying connection was closed: An unexpected error occurred on a receive.
Tls(192): Supported
Tls11(768): Supported
Tls12(3072): Supported
Tls13(12288): Supported

그러니까 기본적으로는 Windows 11 운영체제의 IIS는 TLS 1.0 이상의 보안 프로토콜을 모두 지원하고 있는 것입니다. 다시 말해 오직 TLS 1.2 이상만 지원하고 싶다면 그에 대한 변경을 요합니다.




IIS 서비스에 TLS 1.2만을 적용하기 위한 방법은 다음의 글에 잘 나와 있습니다.

Enabling TLS Configuration on IIS/SMTP Server
; https://support.mailessentials.gfi.com/hc/en-us/articles/360015120800-Enabling-TLS-Configuration-on-IIS-SMTP-Server-

저 글을 정리해 보면, Windows 11은 기본적으로 SSL 3.0에 대해서는 "Enabled" == 0, TLS 1.0 이상에 대해 모두 "Enabled" == 1 값으로 설정된 상태인 것입니다. 실제로 문서에 보면,

Support for TLS System Default Versions included in the .NET Framework 3.5 on Windows Server 2012
; https://support.microsoft.com/en-us/topic/support-for-tls-system-default-versions-included-in-the-net-framework-3-5-on-windows-server-2012-db7ff0cb-fc9e-6530-db50-6a3dfc2834ad

What's new in Windows 10, version 1909 for IT Pros
 - Transport Layer Security (TLS)
; https://learn.microsoft.com/en-us/windows/whats-new/whats-new-windows-10-version-1909#transport-layer-security-tls

iis_tls12_support_1.png

서버는 Windows Server 2012 이상, 클라이언트는 Windows 8 이상에서 TLS 1.0/1.1/1.2가 기본적으로 "Enabled" 상태라고 나옵니다. 따라서, 1.2 이상만 지원하려면 TLS 1.0/1.1 (Windows Server 2016이라면 SSL 3.0) 활성화 상태를 꺼야 하는데요, 이를 위해 다음과 같이 "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SecurityProviders\SCHANNEL\Protocols" 하위에 각각의 보안 프로토콜 이름에 해당하는 키와, 다시 그 하위에 "Server" 키를 추가한 후 REG_DWORD 유형으로 Enabled 값을 0으로 만들어주면 됩니다.

// TLS 1.0 끄기
경로: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SecurityProviders\SCHANNEL\Protocols\TLS 1.0\Server
이름: Enabled
타입: REG_DWORD
값: 0

// TLS 1.1 끄기
경로: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SecurityProviders\SCHANNEL\Protocols\TLS 1.1\Server
이름: Enabled
타입: REG_DWORD
값: 0

위의 설정은 재부팅을 해야 반영되므로 시스템을 다시 시작한 후, 지원 여부를 확인하면 다음과 같은 결과를 얻게 됩니다.

Ssl3(48): Not supported - The underlying connection was closed: An unexpected error occurred on a receive.
Tls(192): Not supported - The underlying connection was closed: An unexpected error occurred on a send.
Tls11(768): Not supported - The underlying connection was closed: An unexpected error occurred on a send.
Tls12(3072): Supported
Tls13(12288): Supported

키 경로에서 유추할 수 있겠지만, 저 설정은 IIS만을 위한 것은 아니라는 점에 유의할 필요가 있습니다.




정리해 보면, 아래의 문제를 일으켰던,

JetBrains Omea Reader에서 TLS 1.2 모드의 https 서버로부터 RSS 구독이 안 되는 경우 해결 방법
; https://www.sysnet.pe.kr/0/0/547

근래의 웹 서버들은 보안상의 이유로 TLS 1.2 이상의 프로토콜만 허용하고 있는 것입니다. 따라서, Windows Server에서도 TLS 1.2만을 허용하려면 (Windows Server 2016의 경우엔 SSL 3.0도 포함해서), TLS 1.0, TLS 1.1에 대한 레지스트리 키를 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SecurityProviders\SCHANNEL\Protocols 경로에 각각 생성하고 "Server" 키 하위로 Enabled를 0으로 만들면 됩니다.

만약 TLS 1.3만 지원하고 싶다면, 당연히 TLS 1.2에 대해서도 동일한 설정을 하면 됩니다.




자, 이렇게 해서 제 웹 사이트("https://www.sysnet.pe.kr")도, ^^; 사실 그다지 보안이 필요한 콘텐츠는 없지만 그냥 TLS 1.1 이하의 프로토콜을 비활성화시켰습니다.

// www.sysnet.pe.kr

Ssl3(48): Not supported - The underlying connection was closed: An unexpected error occurred on a receive.
Tls(192): Not supported - The underlying connection was closed: An unexpected error occurred on a send.
Tls11(768): Not supported - The underlying connection was closed: An unexpected error occurred on a send.
Tls12(3072): Supported
Tls13(12288): Not supported - The underlying connection was closed: An unexpected error occurred on a send.

단지, Windows Server 2022 제품이 아니라서 TLS 1.3은 지원되지 않고 있습니다.




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







[최초 등록일: ]
[최종 수정일: 1/31/2023]

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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  [38]  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12699정성태7/8/20217884VS.NET IDE: 167. Visual Studio 디버깅 중 GC Heap 상태를 보여주는 "Show Diagnostic Tools" 메뉴 사용법
12698정성태7/7/202111846오류 유형: 732. Windows 11 업데이트 시 3% 또는 0%에서 다운로드가 멈춘 경우
12697정성태7/7/20217689개발 환경 구성: 574. Windows 11 (Insider Preview) 설치하는 방법
12696정성태7/6/20218318VC++: 146. 운영체제의 스레드 문맥 교환(Context Switch)을 유사하게 구현하는 방법파일 다운로드2
12695정성태7/3/20218363VC++: 145. C 언어의 setjmp/longjmp 기능을 Thread Context를 이용해 유사하게 구현하는 방법파일 다운로드1
12694정성태7/2/202110381Java: 24. Azure - Spring Boot 앱을 Java SE(Embedded Web Server)로 호스팅 시 로그 파일 남기는 방법 [1]
12693정성태6/30/20218055오류 유형: 731. Azure Web App Site Extension - Failed to install web app extension [...]. {1}
12692정성태6/30/20217982디버깅 기술: 180. Azure - Web App의 비정상 종료 시 남겨지는 로그 확인
12691정성태6/30/20218735개발 환경 구성: 573. 테스트 용도이지만 테스트에 적합하지 않은 Azure D1 공유(shared) 요금제
12690정성태6/28/20219590Java: 23. Azure - 자바(Java)로 만드는 Web App Service - Tomcat 호스팅
12689정성태6/25/202110202오류 유형: 730. Windows Forms 디자이너 - The class Form1 can be designed, but is not the first class in the file. [1]
12688정성태6/24/20219864.NET Framework: 1073. C# - JSON 역/직렬화 시 리플렉션 손실을 없애는 JsonSrcGen [2]파일 다운로드1
12687정성태6/22/20217785오류 유형: 729. Invalid data: Invalid artifact, java se app service only supports .jar artifact
12686정성태6/21/202110291Java: 22. Azure - 자바(Java)로 만드는 Web App Service - Java SE (Embedded Web Server) 호스팅
12685정성태6/21/202110528Java: 21. Azure Web App Service에 배포된 Java 프로세스의 메모리 및 힙(Heap) 덤프 뜨는 방법
12684정성태6/19/20218969오류 유형: 728. Visual Studio 2022부터 DTE.get_Properties 속성 접근 시 System.MissingMethodException 예외 발생
12683정성태6/18/202110441VS.NET IDE: 166. Visual Studio 2022 - Windows Forms 프로젝트의 x86 DLL 컨트롤이 Designer에서 오류가 발생하는 문제 [1]파일 다운로드1
12682정성태6/18/20218066VS.NET IDE: 165. Visual Studio 2022를 위한 Extension 마이그레이션
12681정성태6/18/20217420오류 유형: 727. .NET 2.0 ~ 3.5 + x64 환경에서 System.EnterpriseServices 참조 시 CS8012 경고
12680정성태6/18/20218564오류 유형: 726. python2.7.exe 실행 시 0xc000007b 오류
12679정성태6/18/20219085COM 개체 관련: 23. CoInitializeSecurity의 전역 설정을 재정의하는 CoSetProxyBlanket 함수 사용법파일 다운로드1
12678정성태6/17/20218281.NET Framework: 1072. C# - CoCreateInstance 관련 Inteop 오류 정리파일 다운로드1
12677정성태6/17/20219921VC++: 144. 역공학을 통한 lxssmanager.dll의 ILxssSession 사용법 분석파일 다운로드1
12676정성태6/16/20219816VC++: 143. ionescu007/lxss github repo에 공개된 lxssmanager.dll의 CLSID_LxssUserSession/IID_ILxssSession 사용법파일 다운로드1
12675정성태6/16/20217882Java: 20. maven package 명령어 결과물로 (war가 아닌) jar 생성 방법
12674정성태6/15/20218768VC++: 142. DEFINE_GUID 사용법
... 31  32  33  34  35  36  37  [38]  39  40  41  42  43  44  45  ...