Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 30. 64비트 OS에서의 ChartFX 라이선스 문제 [링크 복사], [링크+제목 복사],
조회: 30050
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)

64비트 OS에서의 ChartFX 라이선스 문제


기억하실 분들이 계실지 모르겠습니다. 지난번에, 이 문제를 설명하면서 "땜빵" 식으로 처리를 했었지요.

오류 유형 : 42. System.ComponentModel.LicenseException 
; https://www.sysnet.pe.kr/2/0/518

그런데, 위의 사건이 있은 이후로 ChartFX가 얹혀진 간단한 예제 프로그램을 만들면서 다시 문제가 발생하기 시작했습니다. 이번에는, 아예 Runtime License를 얻을 수 없다면서 다음과 같은 오류 메시지를 내뱉기 시작했습니다.

x64_runtime_license_error_4.png

{"Couldn't get Run Time license for 'ChartFX.WinForms.Chart'"}

System.ComponentModel.LicenseException was unhandled
  Message="Couldn't get Run Time license for 'ChartFX.WinForms.Chart'"
  Source="ChartFX.WinForms"
  StackTrace:
       at ChartFX.WinForms.Internal.h.a(LicenseContext A_0, Type A_1, Object A_2, Boolean A_3, LicenseProvider A_4)
       at ChartFX.WinForms.Internal.j.a(LicenseContext A_0, Type A_1, Object A_2, Boolean A_3)
       at System.ComponentModel.LicenseManager.ValidateInternalRecursive(LicenseContext context, Type type, Object instance, Boolean allowExceptions, License& license, String& licenseKey)
...  [중간생략] ...       
       at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
       at System.Threading.ThreadHelper.ThreadStart()

휴... 이쯤 되면, 참을만큼 참았습니다. 컴파일 시에 문제가 발생하는 거야 어떻게 해본다고 쳐도, 실행 시에도 이렇게 오류를 내버리니 ^^ 더 이상 방법이 없더군요.




자... 이제 문제를 해결해야 하는데,,, 어떤 방법이 좋을까 가만히 생각해 봤습니다. 대강 2가지 방법이 떠오르더군요.

  • WinDBG / SOS.dll을 이용한 디버깅
  • Sysinternals의 Regmon.exe 또는 ProcMon.exe를 이용한 관련 레지스트리 또는 파일의 문제 추적.

WinDBG를 이용하는 방법은 왠지 하기가 싫더군요. 이유는 난독 처리가 되어 있는 어셈블리 때문이었습니다. 그래서 일단, Procmon.exe를 이용해 보고 나서도 해결이 안되면 WinDBG를 사용하기로 마음을 굳히고, Procmon.exe를 통해서 문제 해결에 나섰습니다.

그나저나, 라이선스 문제와 procmon.exe가 무슨 관계가 있을까... 하고 생각하시는 분들이 계시겠지요.

사실, 로컬 PC에서 라이선스 운운하기 위해서는 필히 로컬 PC의 어딘가에 관련 정보를 저장해야 합니다. 그 과정에서 이용할 수 있는 자원이라고는 "파일" 또는 "레지스트리"뿐이 없고. 그냥 그렇게 ^^ 간단한 문제입니다.

자,,, 이제 비교를 시작해 봤습니다. 우선 기존에 개발 중인 exe 파일은 실행까지는 잘 되었기 때문에 그것을 실행시키는 과정의 레지스트리 Read/Write 작업을 모니터링하고 그 결과물을 파일로 저장했습니다. 이어서, 신규 예제 프로젝트를 실행시키고 오류가 발생하는 시점까지의 레지스트리 Read/Write 작업을 모니터링하고 역시 결과물을 저장해 두었습니다.

오... 그러다 보니, 흥미로운 사실을 하나 발견했습니다.

기존 개발중인 exe 파일은 VC++과의 연동 작업으로 인해 대상 프로세서 유형을 확실히 정해 두어야 했던 탓으로 x86으로 플랫폼이 맞춰져 있던 반면, 새롭게 제작한 예제 응용 프로그램은 "AnyCPU" 유형으로 인해 자연스럽게 x64 유형으로 JIT 컴파일링 되어 실행되어졌다는 사실이었습니다.

그 사실과 함께, 2가지 레지스트리 작업 결과물을 비교해 가던 중에 다음의 라인에서 차이가 나는 것을 발견할 수 있었습니다.

[그림: x64 유형 - 런타임 라이선스 오류가 발생]
x64_runtime_license_error_1.png

[그림: x86 유형 - 정상 실행]
x64_runtime_license_error_2.png

오호... "HKCU\Software\Classes\Licenses\{...GUID...}\(Default)" 값이 x86에서는 읽혀졌던 반면, x64에서는 읽혀지지 않은 것을 확인할 수 있습니다. 실제로, RegEdit.exe로 확인해 보니, x86의 "Wow6432Node" 하위에는 라이선스 문자열이 있었지만 x64 하위에는 존재하지 않았습니다.

아하... 답이 나왔습니다. ChartFX 설치 프로그램이 32bit 응용 프로그램이었기 때문에 관련 레지스트를 Wow6432Node 하위에만 기록을 했을 뿐, 64비트 관련 레지스트리에는 기록을 하지 않았기 때문에 이러한 문제가 발생한 것이었습니다. 그렇게 따져 보니, 지난번 문제의 LC.exe가 정상적으로 실행되지 않았던 의문이 풀리기 시작했습니다. 즉, 64비트용의 LC.exe가 실행되었기 때문에 그때도 역시 라이선스 문자열을 레지스트리에서 찾을 수가 없어 문제가 발생한 것이었습니다.

그렇다면... ^^ Wow6432Node 하위에 있던 그 라이선스 문자열을 64비트 레지스트리 하위에 복사해 주면 문제는 해결되겠군요.




가벼운 마음으로 ^^ Copy & Paste를 하고는 실행시켜 보았습니다.
헛... 그런데 이게 웬일입니까?

오류 유형이 다르긴 하지만, 이번에도 역시 ChartFX 생성자에서 오류가 발생했습니다. 아니... 다른 PC도 아니고, 동일한 PC에서 (64비트라는 점을 감안해서) 동등한 레지스트리 경로의 값에 대해 어떻게 이런 반응을 보일 수가 있을까???

역시나, 가만히 살펴보니 문제가 있습니다.
이해할 수는 없지만, ChartFX 측에서 REG_SZ 유형임에도 불구하고 중간에 "\r\n" 문자를 넣어둔 것이었습니다.

x64_runtime_license_error_3.png

당연히 그러한 개행문자가 포함된 문자열을 regedit.exe의 편집 상자에서는 첫 번째 라인의 라이선스 문자열만 입력시킬 수가 있었고, 암호 해독 과정에서 정상적인 처리를 하지 못하게 만드는 결과를 초래한 것이었습니다.

휴... 귀찮군요. ^^ 그냥 다음과 같이 간단하게 프로그램을 만들어서 실행시켜 주었습니다.

private void Form1_Load(object sender, EventArgs e)
{
  string key = "HKEY_CLASSES_ROOT\\Licenses\\1E1D9DB5-1D37-4a8f-B55E-8315007CACA9";

  string value = "nRamFftbAAAfbAABUNORjcwC1NGW... [중간 생략] ...UIxNENBNz8AAAAA" + "\r\n" +
    "NnB+OqDTCdLLgvev9uwRj74HeWSTUuHEpk... [중간 생략] ...OtGrNQ2WlkkA=";

  Registry.SetValue(key, string.Empty, value);
}

자, 이제 모두 해결되었습니다. (물론, 잊지 않고 지난번에 주석 처리해 두었던 <LC />도 풀어주고. ^^)




문제를 다 해결하고 나서, 혹시나 ChartFX 사이트에 이와 관련된 문의가 있었을까 싶어서 찾아보았더니 다음의 게시물이 검색되었습니다.

Chart FX DevStudio 설치가 안됩니다.
; http://www.chartfxkorea.com/community/com_read.asp?cl_no=6087&CurPage=1&cl_type=NQ

지금이라도 도움이 되려나 싶어, 답변을 달아 놓을라고 했더니... 로그인하라고 해서 포기. ^^;



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/26/2021]

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)
13355정성태5/12/20234267.NET Framework: 2123. C# - Semantic Kernel의 ChatGPT 대화 구현 [1]파일 다운로드1
13354정성태5/12/20234352.NET Framework: 2122. C# - "Use Unicode UTF-8 for worldwide language support" 설정을 한 경우, 한글 입력이 '\0' 문자로 처리
13352정성태5/12/20234081.NET Framework: 2121. C# - Semantic Kernel의 대화 문맥 유지파일 다운로드1
13351정성태5/11/20234523VS.NET IDE: 185. Visual Studio - 원격 Docker container 내에 실행 중인 응용 프로그램에 대한 디버깅 [1]
13350정성태5/11/20233864오류 유형: 859. Windows Date and Time - Unable to continue. You do not have permission to perform this task
13349정성태5/11/20234219.NET Framework: 2120. C# - Semantic Kernel의 Skill과 Function 사용 예제파일 다운로드1
13348정성태5/10/20234083.NET Framework: 2119. C# - Semantic Kernel의 "Basic Loading of the Kernel" 예제
13347정성태5/10/20234466.NET Framework: 2118. C# - Semantic Kernel의 Prompt chaining 예제파일 다운로드1
13346정성태5/10/20234272오류 유형: 858. RDP 원격 환경과 로컬 PC 간의 Ctrl+C, Ctrl+V 복사가 안 되는 문제
13345정성태5/9/20235842.NET Framework: 2117. C# - (OpenAI 기반의) Microsoft Semantic Kernel을 이용한 자연어 처리 [1]파일 다운로드1
13344정성태5/9/20236883.NET Framework: 2116. C# - OpenAI API 사용 - 지원 모델 목록 [1]파일 다운로드1
13343정성태5/9/20234756디버깅 기술: 192. Windbg - Hyper-V VM으로 이더넷 원격 디버깅 연결하는 방법
13342정성태5/8/20234609.NET Framework: 2115. System.Text.Json의 역직렬화 시 필드/속성 주의
13341정성태5/8/20234366닷넷: 2114. C# 12 - 모든 형식의 별칭(Using aliases for any type)
13340정성태5/8/20234499오류 유형: 857. Microsoft.Data.SqlClient.SqlException - 0x80131904
13339정성태5/6/20235300닷넷: 2113. C# 12 - 기본 생성자(Primary Constructors)
13338정성태5/6/20234661닷넷: 2112. C# 12 - 기본 람다 매개 변수파일 다운로드1
13337정성태5/5/20235158Linux: 59. dockerfile - docker exec로 container에 접속 시 자동으로 실행되는 코드 적용
13336정성태5/4/20234995.NET Framework: 2111. C# - 바이너리 출력 디렉터리와 연관된 csproj 설정
13335정성태4/30/20235037.NET Framework: 2110. C# - FFmpeg.AutoGen 라이브러리를 이용한 기본 프로젝트 구성 - Windows Forms파일 다운로드1
13334정성태4/29/20234641Windows: 250. Win32 C/C++ - Modal 메시지 루프 내에서 SetWindowsHookEx를 이용한 Thread 메시지 처리 방법
13333정성태4/28/20234150Windows: 249. Win32 C/C++ - 대화창 템플릿을 런타임에 코딩해서 사용파일 다운로드1
13332정성태4/27/20234164Windows: 248. Win32 C/C++ - 대화창을 위한 메시지 루프 사용자 정의파일 다운로드1
13331정성태4/27/20234127오류 유형: 856. dockerfile - 구 버전의 .NET Core 이미지 사용 시 apt update 오류
13330정성태4/26/20233817Windows: 247. Win32 C/C++ - CS_GLOBALCLASS 설명
13329정성태4/24/20234140Windows: 246. Win32 C/C++ - 직접 띄운 대화창 템플릿을 위한 Modal 메시지 루프 생성파일 다운로드1
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...