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

WPF - There is no registered CultureInfo with the IetfLanguageTag 'ug'.

지난 글에서,

.NET 3.5 이하에서 TextBox에 한글 입력 시 TextChanged 이벤트의 비정상 종료 문제
; https://www.sysnet.pe.kr/2/0/11201

"There is no registered CultureInfo with the IetfLanguageTag 'ug'." 메시지의 System.InvalidOperationException 예외가 발생 후 비정상 종료하는 경우가 있고, 또는 곧바로 비정상 종료하는 경우가 있다고 했는데요. 결과적으로 봤을 때 이 문제는 비정상 종료와 아무런 상관이 없습니다. 단지, 특정 환경에서 한글이 입력된 경우 등록된 Culture 설정이 비정상적일 때 "There is no registered CultureInfo with the IetfLanguageTag 'xx'." 같은 식의 예외가 발생하는 것뿐입니다.

비정상 종료하는 것은 막을 수 없었지만, 왠지 System.InvalidOperationException 예외는 없애고 싶었습니다. 왜냐하면, 제 경우에는 Visual Studio 디버거 상태에서 System.InvalidOperationException 예외에 대해 Thrown 설정을 해두기 때문에 자꾸 이 예외가 걸리는 것이 거슬렸기 때문입니다.

이 예외를 막으려면, 해당 Culture(이 글에서는 ug == LCID 0x480) 설정을 잘 동작하도록 맞춰주면 됩니다. 물론, 실제 ug Culture 정보를 기반으로 맞춰주면 더 좋겠지만, 다음의 글에 나오는 코드를 이용해 적당히 등록하는 것도 가능합니다.

.NET Internationalization: The Developer's Guide to Building Global Windows and Web Applications: Chapter 11 - Custom Cultures
; https://www.codeproject.com/Articles/15175/NET-Internationalization-The-Developer-s-Guide-to

따라서, 다음과 같은 코드를 "관리자 권한"으로 실행해 주면 됩니다.

// sysglobal 어셈블리 참조

using System.Globalization;

class Program
{
    static void Main(string[] args)
    {
        var culture = new CultureAndRegionInfoBuilder("ug", CultureAndRegionModifiers.None);
        var ci = new CultureInfo("en-US");
        var ri = new RegionInfo("US");
        culture.LoadDataFromCultureInfo(ci);
        culture.LoadDataFromRegionInfo(ri);
        culture.Register();
    }
}

위의 코드를 실행해 주면, "c:\Windows\Globalization\ug.NLP" 파일이 생성되고, 다음의 레지스트리 설정도 추가됩니다.

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Nls\CustomLocale
이름: ug
타입: REG_SZ
값: ug

이후, ".NET 3.5 이하에서 TextBox에 한글 입력 시 TextChanged 이벤트의 비정상 종료 문제" 글에 소개된 예제 코드를 실행하면 System.InvalidOperationException 예외는 더 이상 발생하지 않고 곧바로 비정상 종료하게 됩니다.




참고로, ug의 Locale ID가 0x480(1152)이기 때문에 다음의 레지스트리에 0x480에 대한 설정을 찾을 수 있습니다.

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Nls\Language
값 이름: 00000480

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Nls\Locale
값 이름: 00000480

또한 키보드 레이아웃에도 Uyghur 관련 설정이 있습니다.

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Keyboard Layouts\00000480
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Keyboard Layouts\00010480




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







[최초 등록일: ]
[최종 수정일: 5/19/2017]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  [52]  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12329정성태9/16/202012345오류 유형: 650. ASUS 메인보드 관련 소프트웨어 설치 후 ArmouryCrate.UserSessionHelper.exe 프로세스 무한 종료 현상
12328정성태9/16/202012533VS.NET IDE: 150. TFS의 이력에서 "Get This Version"과 같은 기능을 Git으로 처리한다면?
12327정성태9/12/202010155.NET Framework: 938. C# - ICS(Internet Connection Sharing) 제어파일 다운로드1
12326정성태9/12/20209643개발 환경 구성: 516. Azure VM의 Network Adapter를 실수로 비활성화한 경우
12325정성태9/12/20209219개발 환경 구성: 515. OpenVPN - 재부팅 후 ICS(Internet Connection Sharing) 기능이 동작 안하는 문제
12324정성태9/11/202010468개발 환경 구성: 514. smigdeploy.exe를 이용한 Windows Server 2016에서 2019로 마이그레이션 방법
12323정성태9/11/20209389오류 유형: 649. Copy Database Wizard - The job failed. Check the event log on the destination server for details.
12322정성태9/11/202010330개발 환경 구성: 513. Azure VM의 RDP 접속 위치 제한 [1]
12321정성태9/11/20208722오류 유형: 648. netsh http add urlacl - Error: 183 Cannot create a file when that file already exists.
12320정성태9/11/20209910개발 환경 구성: 512. RDP(원격 데스크톱) 접속 시 비밀 번호를 한 번 더 입력해야 하는 경우
12319정성태9/10/20209662오류 유형: 647. smigdeploy.exe를 Windows Server 2016에서 실행할 때 .NET Framework 미설치 오류 발생
12318정성태9/9/20209151오류 유형: 646. OpenVPN - "TAP-Windows Adapter V9" 어댑터의 "Network cable unplugged" 현상
12317정성태9/9/202011457개발 환경 구성: 511. Beats용 Kibana 기본 대시 보드 구성 방법
12316정성태9/8/20209890디버깅 기술: 170. WinDbg Preview 버전부터 닷넷 코어 3.0 이후의 메모리 덤프에 대해 sos.dll 자동 로드
12315정성태9/7/202012175개발 환경 구성: 510. Logstash - FileBeat을 이용한 IIS 로그 처리 [2]
12314정성태9/7/202010590오류 유형: 645. IIS HTTPERR - Timer_MinBytesPerSecond, Timer_ConnectionIdle 로그
12313정성태9/6/202011899개발 환경 구성: 509. Logstash - 사용자 정의 grok 패턴 추가를 이용한 IIS 로그 처리
12312정성태9/5/202015849개발 환경 구성: 508. Logstash 기본 사용법 [2]
12311정성태9/4/202011026.NET Framework: 937. C# - 간단하게 만들어 보는 리눅스의 nc(netcat), json_pp 프로그램 [1]
12310정성태9/3/202010274오류 유형: 644. Windows could not start the Elasticsearch 7.9.0 (elasticsearch-service-x64) service on Local Computer.
12309정성태9/3/202010029개발 환경 구성: 507. Elasticsearch 6.6부터 기본 추가된 한글 형태소 분석기 노리(nori) 사용법
12308정성태9/2/202011264개발 환경 구성: 506. Windows - 단일 머신에서 단일 바이너리로 여러 개의 ElasticSearch 노드를 실행하는 방법
12307정성태9/2/202012051오류 유형: 643. curl - json_parse_exception / Invalid UTF-8 start byte
12306정성태9/1/202010196오류 유형: 642. SQL Server 시작 오류 - error code 10013
12305정성태9/1/202011106Windows: 172. "Administered port exclusions"이 아닌 포트 범위 항목을 삭제하는 방법
12304정성태8/31/202010062개발 환경 구성: 505. 윈도우 - (네트워크 어댑터의 우선순위로 인한) 열거되는 IP 주소 순서를 조정하는 방법
... 46  47  48  49  50  51  [52]  53  54  55  56  57  58  59  60  ...