Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 30. 64비트 OS에서의 ChartFX 라이선스 문제 [링크 복사], [링크+제목 복사],
조회: 35301
글쓴 사람
정성태 (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)
13667정성태7/7/20246623닷넷: 2273. C# - 리눅스 환경에서의 Hyper-V Socket 연동 (AF_VSOCK)파일 다운로드1
13666정성태7/7/20247700Linux: 74. C++ - Vsock 예제 (Hyper-V Socket 연동)파일 다운로드1
13665정성태7/6/20247881Linux: 73. Linux 측의 socat을 이용한 Hyper-V 호스트와의 vsock 테스트파일 다운로드1
13663정성태7/5/20247478닷넷: 2272. C# - Hyper-V Socket 통신(AF_HYPERV, AF_VSOCK)의 VMID Wildcards 유형파일 다운로드1
13662정성태7/4/20247491닷넷: 2271. C# - WSL 2 VM의 VM ID를 알아내는 방법 - Host Compute System API파일 다운로드1
13661정성태7/3/20247413Linux: 72. g++ - 다른 버전의 GLIBC로 소스코드 빌드
13660정성태7/3/20247522오류 유형: 912. Visual C++ - Linux 프로젝트 빌드 오류
13659정성태7/1/20247860개발 환경 구성: 715. Windows - WSL 2 환경의 Docker Desktop 네트워크
13658정성태6/28/20248238개발 환경 구성: 714. WSL 2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법 - 두 번째 이야기
13657정성태6/27/20247917닷넷: 2270. C# - Hyper-V Socket 통신(AF_HYPERV, AF_VSOCK)을 위한 EndPoint 사용자 정의
13656정성태6/27/20248094Windows: 264. WSL 2 VM의 swap 파일 위치
13655정성태6/24/20247851닷넷: 2269. C# - Win32 Resource 포맷 해석파일 다운로드1
13654정성태6/24/20247788오류 유형: 911. shutdown - The entered computer name is not valid or remote shutdown is not supported on the target computer.
13653정성태6/22/20247937닷넷: 2268. C# 코드에서 MAKEINTREOURCE 매크로 처리
13652정성태6/21/20249250닷넷: 2267. C# - Linux 환경에서 (Reflection 없이) DLL AssemblyFileVersion 구하는 방법파일 다운로드2
13651정성태6/19/20248488닷넷: 2266. C# - (Reflection 없이) DLL AssemblyFileVersion 구하는 방법파일 다운로드1
13650정성태6/18/20248410개발 환경 구성: 713. "WSL --debug-shell"로 살펴보는 WSL 2 VM의 리눅스 환경
13649정성태6/18/20247961오류 유형: 910. windbg - !py 확장 명령어 실행 시 "failed to find python interpreter" (2)
13648정성태6/17/20248281오류 유형: 909. C# - DynamicMethod 사용 시 System.TypeAccessException
13647정성태6/16/20249345개발 환경 구성: 712. Windows - WSL 2의 네트워크 통신 방법 - 세 번째 이야기 (같은 IP를 공유하는 WSL 2 인스턴스) [1]
13646정성태6/14/20247761오류 유형: 908. Process Explorer - "Error configuring dump resources: The system cannot find the file specified."
13645정성태6/13/20248197개발 환경 구성: 711. Visual Studio로 개발 시 기본 등록하는 dev tag 이미지로 Docker Desktop k8s에서 실행하는 방법
13644정성태6/12/20248868닷넷: 2265. C# - System.Text.Json의 기본적인 (한글 등에서의) escape 처리 [1]
13643정성태6/12/20248321오류 유형: 907. MySqlConnector 사용 시 System.IO.FileLoadException 오류
13642정성태6/11/20248199스크립트: 65. 파이썬 - asgi 버전(2, 3)에 따라 달라지는 uvicorn 호스팅
13641정성태6/11/20248673Linux: 71. Ubuntu 20.04를 22.04로 업데이트
1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...