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

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
14013정성태9/14/2025223닷넷: 2363. C# - Whisper.NET Library를 이용해 음성을 텍스트로 변환 및 번역하는 예제파일 다운로드1
14012정성태9/9/2025749닷넷: 2362. C# - Windows.Media.Ocr: 윈도우 운영체제에 포함된 OCR(Optical Character Recognition)파일 다운로드1
14011정성태9/7/20251293닷넷: 2361. C# - Linux 환경의 readlink 호출
14010정성태9/1/20251454오류 유형: 983. apt update 시 "The repository 'http://deb.debian.org/debian buster Release' does not have a Release file." 오류
14009정성태8/28/20251832닷넷: 2360. C# 14 - (11) Expression Tree에 선택적 인수와 명명된 인수 허용파일 다운로드1
14008정성태8/26/20252154닷넷: 2359. C# 14 - (10) 복합 대입 연산자의 오버로드 지원파일 다운로드1
14007정성태8/25/20252523닷넷: 2358. C# - 현재 빌드에 적용 중인 컴파일러 버전 확인 방법 (#error version)
14006정성태8/23/20252752Linux: 121. Linux - snap 패키지 관리자로 설치한 소프트웨어의 디렉터리 접근 제한
14005정성태8/21/20252234오류 유형: 982. sudo: unable to load /usr/libexec/sudo/sudoers.so: libssl.so.3: cannot open shared object file: No such file or directory
14004정성태8/21/20252483오류 유형: 981. dotnet 실행 시 No usable version of the libssl was found
14003정성태8/21/20252752닷넷: 2357. C# 14 - (9) 새로운 지시자 추가 (Ignored directives)
14002정성태8/20/20252768오류 유형: 980. C# - appsettings.json 파일의 설정값이 적용 안 된다면?
14001정성태8/19/20255782닷넷: 2356. .NET SDK 10 - 단일 소스 코드 파일을 빌드/실행하는 기능을 "dotnet" 명령어에 추가 [1]
14000정성태8/18/20252859오류 유형: 979. ERROR: failed to solve: failed to read dockerfile: open Dockerfile: no such file or directory
13999정성태8/15/20252830닷넷: 2355. C# 14 - (8) null 조건부 연산자 개선 - 대입문에도 사용 가능파일 다운로드1
13998정성태8/14/20252765닷넷: 2354. C# 14 - (7) 확장 메서드에 정적 메서드와 속성 지원을 위한 전용 구문 추가파일 다운로드1
13997정성태8/14/20252869Linux: 120. docker 컨테이너로 매핑된 볼륨에 컨테이너 측의 사용자 ID를 유지하면서 복사하는 방법
13996정성태8/13/20252365오류 유형: 978. Unable to find the requested .Net Framework Data Provider.
13995정성태8/13/20252523개발 환경 구성: 754. Visual C++ - 리눅스 빌드를 위한 Ubuntu 18 docker 컨테이너 설정
13994정성태8/12/20252271오류 유형: 977. SQL Server - User, group, or role '...' already exists in the current database. (Microsoft SQL Server, Error: 15023)
13993정성태8/11/20253043오류 유형: 976. Microsoft.ML.OnnxRuntimeGenAI 패키지 사용 시 "cublasLt64_12.dll" which is missing. (Error 126: "The specified module could not be found.") 오류
13992정성태8/11/20253038닷넷: 2353. C# - Foundry Local을 이용한 gpt-oss-20b 모델 사용파일 다운로드1
13991정성태8/9/20252785오류 유형: 975. winget - Foundry Local 패키지 업데이트가 안 되는 문제
13990정성태8/8/20252295Windows: 283. Time zone 설정이 없는 Windows Server 2025
13989정성태8/8/20253175닷넷: 2352. C# - Windows S-mode 환경인지 체크하는 방법파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...