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

JetBrains Omea Reader에서 TLS 1.2 모드의 https 서버로부터 RSS 구독이 안 되는 경우 해결 방법

언젠가부터, Omea Reader로는 구독이 안 되는 RSS들이 나오기 시작했습니다. 일례로, "https://shinyoungjin.life/rss.xml" RSS의 경우 구독을 시도하면,

https_tls12_1.png

"The underlying connection was closed: An unexpected error occurred on a send." 오류가 발생했는데요, 예전에는 그냥... 뭔가 새로운 RSS 포맷에 대한 지원을 하지 못해서 그런가 보다 했는데요, 아래의 사건을 겪게 되면서,

C# - WebClient로 https 호출 시 "The request was aborted: Could not create SSL/TLS secure channel" 예외 발생
; https://www.sysnet.pe.kr/2/0/13233

어쩌면 Omea Reader도 내부에서 사용한 HttpWebRequest가 TLS 1.2 서버에 대한 통신 오류를 겪고 있는 것이 아닌가... 하는 의심이 들었습니다. 그리고 테스트를 해봤는데요, 방법은 간단합니다.

우선, 제 웹 사이트의 RSS는 정상적으로 Omea Reader가 읽어들이므로, sysnet.pe.kr에 페이지 하나를 추가해 다음과 같이 문제의 RSS 파일을 읽어 그대로 반환하는 코드를 작성한 후,

string url = "https://shinyoungjin.life/rss.xml";

WebClient wc = new WebClient();
wc.Encoding = Encoding.UTF8;
ServicePointManager.SecurityProtocol |= SecurityProtocolType.Tls12;
outputText = wc.DownloadString(url);

Response.Clear();
Response.ContentType = contentType;
Response.ContentEncoding = Encoding.UTF8;
Response.Write(outputText);
Response.End();

저 페이지 링크를 대상으로 Omea Reader에서 구독을 시도했더니 ^^ 정상적으로 됩니다. 즉, RSS 파일 내용에는 아무런 문제가 없었으며 https 서버의 문제였던 것입니다.




자, 그럼 원인을 알았으니 Omea Reader의 오류를 어떻게 고칠 수 있을까요?

우선, 해당 프로그램은 오픈 소스가 아니기 때문에 소스 코드를 수정할 수는 없습니다. 따라서 "ServicePointManager.SecurityProtocol |= SecurityProtocolType.Tls12;" 코드를 적용하는 방법은 선택할 수 없습니다.

그다음, app.config에 DontEnableSchUseStrongCrypto 옵션을 설정하는 것은 소스 코드 변경 없이도 가능하지만, 아쉽게도 Omea Reader 응용 프로그램은 .NET Framework 1.1로 만들어졌기 때문에 그 옵션 자체를 지원하지 않습니다. 현재 .NET Framework 1.1은 Windows 8 / Windows Server 2012 이후부터 사라졌는데요, 다행히 CLR 2.0에서 1.1에 대한 하위 호환을 유지하므로 .NET Framework 2.0 ~ 3.5가 설치된 PC에서는 여전히 Omea Reader를 실행할 수 있는 상태입니다.

그렇다면 supportedRuntime을 이용해 명시적으로 .NET 4+ 런타임으로 실행하도록 만들면 어떨까요?

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <startup><supportedRuntime version="v4.0" /></startup>
    <runtime>
        <AppContextSwitchOverrides value="Switch.System.Net.DontEnableSchUseStrongCrypto=false" />
    </runtime>
</configuration>

그런 경우, Omea Reader가 참조한 DLL 중에서 (IL Only 유형이 아닌) "Mixed mode assembly"로 만들어진 것이 있어 실행 시 다음과 같은 예외가 발생합니다.

System.IO.FileLoadException: Mixed mode assembly is built against version 'v1.1.4322' of the runtime and cannot be loaded in the 4.0 runtime without additional configuration information.
   at iv.f()
   at JetBrains.Omea.MainFrame.u(Object A_0, EventArgs A_1)
   at System.Windows.Forms.Timer.OnTick(EventArgs e)
   at System.Windows.Forms.Timer.TimerNativeWindow.WndProc(Message& m)
   at System.Windows.Forms.NativeWindow.Callback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)

이로써 절망에 빠지는 순간... ^^; 오류 메시지의 "without additional configuration information." 문구가 눈에 들어왔습니다. 그렇다면, 부가 설정으로 저 상황을 해결할 수 있다는 건데요, 오호~~~ 검색으로 답을 찾았습니다. ^^

Mixed mode assembly is built against version 'v1.1.4322'
; https://stackoverflow.com/questions/4018924/mixed-mode-assembly-is-built-against-version-v1-1-4322

무려 12년 전의 Q&A가 이렇게 도움이 되는군요. ^^ 그래서 OmeaReader.exe.config을 다음과 같이 바꿔서,

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <startup useLegacyV2RuntimeActivationPolicy="true">
       <supportedRuntime version="v4.0" />
    </startup>

    <runtime>
        <AppContextSwitchOverrides value="Switch.System.Net.DontEnableSchUseStrongCrypto=false" />
    </runtime>
</configuration>

실행했더니 정상적으로 ^^ TLS 1.2 사이트에 대한 문제를 해결했습니다.

(이 방법 외에도, 레지스트리 설정을 통해 전역적으로 TLS 1.2(또는, 최신 버전의 보안 프로토콜)를 사용하게 만들어 해결하는 것도 가능합니다.)




혹시, 또 다른 해결책이 있을까요? 재미 삼아 차선책으로 역어셈블을 고려할 수 있습니다. 그런데, OmeaReader는 전체적으로 난독화 처리가 되었기 때문에 역어셈블 후 대상 소스 코드를 찾아 다시 컴파일 시키는 것이 쉽지 않다는 문제가 있습니다.

다른 방법이 없다면 그렇게라도 해야겠지만, 다행히 우리에게는 ^^ dnSpy가 있습니다. 그래서, 지난 글에 작성한 방법을 적용하면 되는데요,

dnSpy를 이용해 소스 코드가 없는 .NET 어셈블리의 코드를 변경하는 방법
; https://www.sysnet.pe.kr/2/0/13234

위의 글에서 적용한 "System.Windows.Forms.MessageBox.Show("Loaded");" 코드 대신 이번에는 "ServicePointManager.SecurityProtocol |= (SecurityProtocolType)0xC00;" 코드를 사용하면 됩니다.

그렇게 적용한 HTMLPlugin.dll을 기존 파일에 덮어쓴 다음 실행했더니,

omea_reader_tls12_support_1.png

위와 같이 TLS 1.2가 적용된 웹 서버로부터 정상적으로 RSS 파일을 읽어와 잘 보여주고 있습니다. ^^

(혹시 필요한 분들이 계실지 몰라, OmeaReader.exe.config 파일과 변경된 "HTMLPlugin.dll"을 첨부합니다.)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/30/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)
395정성태3/24/201117702윈도우 7/R2 - C 드라이브 용량이 부족해 SP1 설치가 안된다면?
394정성태3/23/201144170윈도우 업데이트 다운로드 폴더를 변경하는 방법 [11]
393정성태3/23/201113628누가 정치를 해야 하는가? [1]
392정성태3/19/201116649IE 9 - 사이트 고정된 바로가기의 보안 기능
391정성태3/17/201116354파수닷컴 관련하여 인터넷 익스플로러 9 작동 중지 현상에 대해서 [1]
390정성태3/15/201114701NT 서비스 단위로 CPU 사용률을 확인하는 방법
389정성태3/10/201120849Windows 7/2008 R2 SP1 설치로 늘어난 디스크 용량 줄이기 [3]
388정성태2/27/201114309[종료] 메모리(RAM) DDR3 2GB * 2EA를 드립니다. [1]
387정성태2/26/201124440기가바이트(GIGABYTE) GA-770TA-UD3 - RAID 1 구성 [1]
386정성태2/22/201113963Windows XP를 Windows 7로 업그레이드
385정성태2/21/201122260실패한 Windows 7 SP1 설치 [2]
384정성태2/17/201114940파워 서플라이(전원공급장치)에서 어떤 부품이 중요하다고 생각하세요?
383정성태2/17/201113291트레이 윈도우가 속한 프로세스 찾기
382정성태2/16/201116901RSupport(알서포트)를 이용한 원격 지원 방법
381정성태2/16/201115169노트북 램 8GB - 페이지 파일(pagefile.sys)을 없애다.
380정성태2/16/201113706인터넷 익스플로러 9 RC - 정식 버전 때 '재설치'해야 할 생각에 망설여진다면?
379정성태2/7/201121091Windows 7 - Taskhost.exe CPU 점유 문제
378정성태1/31/201115721System 이벤트 로그 - amdkmdag
376정성태1/13/201114992모니터 - 삼성 BX2431, 알파스캔 TLED24
374정성태1/7/201114590윈도우 라이브 메신저 - Windows Server 2008 R2 에서 "Remote Assistance" 활성화 하기
373정성태12/29/201013324나니아 연대기 - 새벽 출정호의 항해 트레일러 음악
372정성태12/25/201014798내용 복사(Copy & Paste)를 막은 블로그가 줄어들길 바랍니다!!! [8]
371정성태12/22/201049078뽀모도로 타이머 - 데스크톱용 [4]
370정성태12/20/201017923노트북과 PC에서 iPad를 충전시킴 ^^ [1]
369정성태12/15/201016658Adobe Reader - 마지막으로 본 페이지 기억시키는 방법 [3]
368정성태12/12/201022618새로운 취미 ^^ - 레고 마인드스톰 (LEGO Mindstorms) [2]
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...