Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)
(시리즈 글이 3개 있습니다.)
개발 환경 구성: 48. 개발자 PC 환경 - 유니코드(Unicode)를 위한 설정
; https://www.sysnet.pe.kr/2/0/762

.NET Framework: 2122. C# - "Use Unicode UTF-8 for worldwide language support" 설정을 한 경우, 한글 입력이 '\0' 문자로 처리
; https://www.sysnet.pe.kr/2/0/13354

개발 환경 구성: 728. 윈도우 환경의 개발자를 위한 UTF-8 환경 설정
; https://www.sysnet.pe.kr/2/0/13775




윈도우 환경의 개발자를 위한 UTF-8 환경 설정

제가 예전에는,

개발자 PC 환경 - 유니코드(Unicode)를 위한 설정
; https://www.sysnet.pe.kr/2/0/762

자신이 개발하는 프로그램의 유니코드를 강제할 수 있도록 "Locale(English)" 환경을 설정하라고 했었는데요, 현재는 저도 이 방법을 쓰지는 않고 대신 다른 설정을 사용하고 있습니다. ^^

근래에는 UTF-8이 대세이기 때문에 마이크로소프트도 이에 대한 지원을 꽤나(?) 오래 전부터 추가해 두었는데요, 예전에도 한번 소개한 적이 있습니다.

"Beta: Use Unicode UTF-8 for worldwide language support"
; https://www.sysnet.pe.kr/2/0/11559#utf8

제어판 / "Region"을 선택해 뜨는 창에서 "Administrative" 탭을 눌러 "Language for non-Unicode programs" 그룹에 있는 "Change system locale..." 버튼을 누르면,

cmd_support_han_4.png

위의 그림과 같이 "Use Unicode UTF-8 for worldwide language support" 옵션이 있습니다. 저 글을 2018년에 썼는데, 6년여가 지난 지금도 여전히 "베타" 딱지를 떼지 못했군요. ^^; (아마도 제가 아는 범위 내에서는, 마이크로소프트의 제품군에 이렇게 오래 베타를 유지한 기능은 이게 처음인 것 같습니다.)

저 옵션을 선택하면 (부팅이 필요합니다.), "명령행" 윈도우의 기본 코드 페이지가 65001(UTF-8)로 설정됩니다.

// "Use Unicode UTF-8 for worldwide language support" 옵션을 선택한 환경 (영문/한글 윈도우 무관)
c:\temp> chcp
Active code page: 65001

// 저 옵션을 선택하기 전이라면, 영문 윈도우의 경우 437, 한글 윈도우의 경우는 949가 기본값입니다.

따라서, 당연히 기존에 ks_c_5601-1987 인코딩으로 저장돼 있던 모든 문서들의 한글(및 기타 non-ascii 문자)이 깨져 나오는 문제가 발생합니다. (실수로 해당 파일을 메모장 등으로 열었다가 저장이라도 하면 모든 한글 문자를 망가뜨리는 것이니 주의가 필요합니다.)

그나마 근래에는 Visual Studio를 비롯해 메모장까지도 기본 저장을 UTF-8로 하기 때문에 한글이 깨지는 경우를 많이 볼 수는 없을 것입니다.

어쨌든, 일단 위와 같이 설정한 PC에서는 이후부터 모든 파일을 UTF-8로 (기본) 저장하는 효과를 얻기 때문에 code page 문제로 인한 한글(및 기타 유니코드 문자들이) 깨지는 문제를 해결할 수 있습니다. 결국, 여러분이 만드는 프로그램 역시 자연스럽게 유니코드를 지원하도록 만들 수밖에 없는 효과를 얻게 되는 것이니, 개발자라면 필수로 설정해야 할 옵션이 되겠습니다. ^^

제 경우에 저 글을 썼던 2018년 즈음부터 이 옵션을 켜서 쓰고 있는데, 일부 문제는 있었지만 그런대로 근래에는 대부분의 프로그램들이 유니코드를 지원해 딱히 큰 문제는 없었던 것 같습니다. (그러고 보니, 증권 관련 OpenAPI 다룰 때 증권사 측의 프로그램에 한글이 깨지는 문제가 있어 불편했던 적이 있습니다.)

아직 이 옵션을 적용하지 않은 상태로 이 글을 읽는 개발자가 있다면??? 지금 당장 제어판을 열어 꼭 설정하시길 바랍니다. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 10/23/2024]

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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  [114]  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11135정성태1/20/201722253Windows: 134. Windows Server 2016의 작업 표시줄에 있는 시계가 사라졌다면? [1]
11134정성태1/20/201730396.NET Framework: 636. System.Threading.Timer를 이용해 타이머 작업을 할 때 유의할 점 [5]파일 다운로드1
11133정성태1/20/201726313.NET Framework: 635. C# 개발자를 위한 Win32 DLL export 함수의 호출 규약 (2) - x86 환경의 __fastcall [1]파일 다운로드1
11132정성태1/19/201738308.NET Framework: 634. C# 개발자를 위한 Win32 DLL export 함수의 호출 규약 (1) - x86 환경에서의 __cdecl, __stdcall에 대한 Name mangling [1]파일 다운로드1
11131정성태1/13/201726743.NET Framework: 633. C# - IL 코드 분석을 위한 팁 [2]
11130정성태1/11/201727781.NET Framework: 632. x86 실행 환경에서 SECURITY_ATTRIBUTES 구조체를 CreateEvent에 전달할 때 예외 발생파일 다운로드1
11129정성태1/11/201731649.NET Framework: 631. async/await에 대한 "There Is No Thread" 글의 부가 설명 [9]파일 다운로드1
11128정성태1/9/201724837.NET Framework: 630. C# - Interlocked.CompareExchange 사용 예제 [3]파일 다운로드1
11127정성태1/8/201726116기타: 63. (개발자를 위한) Visual Studio의 "with MSDN" 라이선스 설명
11126정성태1/7/201730976기타: 62. Edge 웹 브라우저의 즐겨찾기(Favorites)를 편집/백업/복원하는 방법 [1]파일 다운로드1
11125정성태1/7/201727759개발 환경 구성: 310. IIS - appcmd.exe를 이용해 특정 페이지에 클라이언트 측 인증서를 제출하도록 설정하는 방법
11124정성태1/4/201731000개발 환경 구성: 309. 3년짜리 유효 기간을 제공하는 StartSSL [2]
11123정성태1/3/201726413.NET Framework: 629. .NET Core의 dotnet.exe CLI 명령어 확장 방법 [1]
11122정성태1/3/201724354.NET Framework: 628. TransactionScope에 사용자 정의 트랜잭션을 참여시키는 방법 [2]파일 다운로드1
11121정성태1/1/201722190개발 환경 구성: 308. "ASP.NET Core Web Application (.NET Core)"와 "ASP.NET Core Web Application (.NET Framework)" 차이점
11120정성태12/25/201630370개발 환경 구성: 307. ASP.NET Core Web Application을 IIS에서 호스팅하는 방법
11119정성태12/23/201650859개발 환경 구성: 306. Visual Studio Code에서 Python 개발 환경 구성 [2]
11118정성태12/22/201639927오류 유형: 374. Python 64비트 설치 시 0x80070659 오류 발생 [3]
11117정성태12/21/201625272웹: 35. nopCommerce 예제 사이트 구성 방법
11116정성태12/21/201627662디버깅 기술: 84. NopCommerce의 Autofac 부하(CPU, Memory) [2]
11115정성태12/21/201630576Windows: 133. 윈도우 서버 2016에서 플래시가 동작하지 않는 경우 [2]
11114정성태12/19/201642462Windows: 132. 역슬래시(backslash) 문자가 왜 통화 표기 문자(한글인 경우 "\")로 보일까요? [2]
11113정성태12/6/201622577오류 유형: 373. ICOMAdminCatalog::GetCollection에서 CO_E_ISOLEVELMISMATCH(0x8004E02F) 오류 발생파일 다운로드1
11112정성태11/23/201627630오류 유형: 372. MySQL 서비스가 올라오지 않는 경우 - Error 1067
11111정성태11/23/201636449.NET Framework: 627. C++로 만든 DLL을 C#에서 사용하기 [2]
11110정성태11/17/201624471.NET Framework: 626. Commit 메모리가 낮은 상황에서도 메모리 부족(Out-of-memory) 예외 발생 [2]
... 106  107  108  109  110  111  112  113  [114]  115  116  117  118  119  120  ...