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

C# - "Use Unicode UTF-8 for worldwide language support" 설정을 한 경우, 한글 입력이 '\0' 문자로 처리

다음과 같이 간단하게 코딩한 후,

Console.Write("입력: ");
string txt = Console.ReadLine();
Console.WriteLine(txt);

입력을 한글로 주면 txt에는 한글 문자만큼의 '\0' 문자가 반환됩니다.

net_kor_support_1.png




이것은 환경의 문제입니다. 제어판의 Region 창에서 다음과 같이 "Beta: Use Unicode UTF-8 for worldwide language support" 옵션을 적용한 환경의 경우,

cmd_support_han_4.png

저렇게 .NET 환경의 Console.ReadLine()으로 한글을 읽는 경우 '\0' 문자로 반환됩니다. 실제로, 저 옵션을 설정하지 않은 영문/한글 윈도우의 경우에는 한글 입력이 잘됩니다.

이런 문제를 해결하려면 Console.InputEncoding을 다음과 같이 바꿔줘야 합니다.

Console.InputEncoding = System.Text.Encoding.Unicode;
Console.OutputEncoding = System.Text.Encoding.UTF8;

Console.Write("입력: ");
string txt = Console.ReadLine();
Console.WriteLine(txt);

이후에는 정상적으로 입력한 한글이 txt 변수에 보관되는 것을 확인할 수 있습니다.




참고로, "Beta: Use Unicode UTF-8 for worldwide language support" 옵션 설정이 된 환경에서는 Console.InputEncoding의 기본값이 (CodePage가 65001에 해당하는) "System.Text.UTF8Encoding+UTF8EncodingSealed"입니다.

// Windows 11 + Beta: Use Unicode UTF-8 for worldwide language support

Console.WriteLine(Console.InputEncoding); // System.Text.UTF8Encoding+UTF8EncodingSealed
                                          // Console.InputEncoding.EncodingName == Unicode (UTF-8)
                                          // Console.InputEncoding.CodePage == 65001
                                          // Console.InputEncoding.HeaderName == utf-8
                                          // Console.InputEncoding.WindowsCodePage == 1200
Console.WriteLine(System.Text.Encoding.Default); // System.Text.UTF8Encoding+UTF8EncodingSealed

반면 일반적인 한글/영문 윈도우에서는 이렇게 나옵니다.

// 한글 Windows 11

Console.WriteLine(Console.InputEncoding); // System.Text.OSEncoding 
                                          // Console.InputEncoding.EncodingName == (Code Page - 949)
                                          // Console.InputEncoding.CodePage == 949
Console.WriteLine(System.Text.Encoding.Default); // System.Text.UTF8Encoding+UTF8EncodingSealed

// 영문 Windows 11

Console.WriteLine(Console.InputEncoding); // System.Text.OSEncoding 
                                          // Console.InputEncoding.EncodingName == (Code Page - 437)
                                          // Console.InputEncoding.CodePage == 437
Console.WriteLine(System.Text.Encoding.Default); // System.Text.UTF8Encoding+UTF8EncodingSealed

따라서, "Beta: Use Unicode UTF-8 for worldwide language support" 옵션이 설정된 환경을 고려한다면 다음과 같은 처리를 하는 것도 좋을 듯합니다. ^^

if (Console.InputEncoding.CodePage == 65001)
{
    Console.InputEncoding = System.Text.Encoding.Unicode;
}

Console.Write("입력: ");
string txt = Console.ReadLine();
Console.WriteLine(txt);




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







[최초 등록일: ]
[최종 수정일: 5/13/2023]

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)
13732정성태9/17/2024328개발 환경 구성: 724. ARM + docker 환경에서 .NET 8 설치
13731정성태9/15/2024739개발 환경 구성: 723. C# / Visual C++ - Control Flow Guard (CFG) 활성화 [1]파일 다운로드2
13730정성태9/10/2024995오류 유형: 922. docker - RULE_APPEND failed (No such file or directory): rule in chain DOCKER
13729정성태9/9/20241358C/C++: 173. Windows / C++ - AllocConsole로 할당한 콘솔과 CRT 함수 연동파일 다운로드1
13728정성태9/7/20241405C/C++: 172. Windows - C 런타임에서 STARTUPINFO의 cbReserved2, lpReserved2 멤버를 사용하는 이유파일 다운로드1
13727정성태9/6/20241665개발 환경 구성: 722. ARM 플랫폼 빌드를 위한 미니 PC(?) - Khadas VIM4 [1]
13726정성태9/5/20241396C/C++: 171. C/C++ - 윈도우 운영체제에서의 file descriptor와 HANDLE파일 다운로드1
13725정성태9/4/20241131디버깅 기술: 201. WinDbg - sos threads 명령어 실행 시 "Failed to request ThreadStore"
13724정성태9/3/20241389닷넷: 2296. Win32/C# - 자식 프로세스로 HANDLE 상속파일 다운로드1
13723정성태9/2/20242847C/C++: 170. Windows - STARTUPINFO의 cbReserved2, lpReserved2 멤버 사용자 정의파일 다운로드2
13722정성태9/2/20241220C/C++: 169. C/C++ - CRT(C Runtime) 함수에 의존성이 없는 프로젝트 생성
13721정성태8/30/20241370C/C++: 168. Visual C++ CRT(C Runtime DLL: msvcr...dll)에 대한 의존성 제거 - 두 번째 이야기
13720정성태8/29/20241234VS.NET IDE: 193. C# - Visual Studio의 자식 프로세스 디버깅
13719정성태8/28/20241276Linux: 79. C++ - pthread_mutexattr_destroy가 없다면 메모리 누수가 발생할까요?
13718정성태8/27/20241928오류 유형: 921. Visual C++ - error C1083: Cannot open include file: 'float.h': No such file or directory [2]
13717정성태8/26/20241453VS.NET IDE: 192. Visual Studio 2022 - Windows XP / 2003용 C/C++ 프로젝트 빌드
13716정성태8/21/20241270C/C++: 167. Visual C++ - 윈도우 환경에서 _execv 동작
13715정성태8/19/20241515Linux: 78. 리눅스 C/C++ - 특정 버전의 glibc 빌드 (docker-glibc-builder)
13714정성태8/19/20241598닷넷: 2295. C# 12 - 기본 생성자(Primary constructors) (책 오타 수정) [3]
13713정성태8/16/20241958개발 환경 구성: 721. WSL 2에서의 Hyper-V Socket 연동
13712정성태8/14/20241916개발 환경 구성: 720. Synology NAS - docker 원격 제어를 위한 TCP 바인딩 추가
13711정성태8/13/20242374Linux: 77. C# / Linux - zombie process (defunct process)파일 다운로드1
13710정성태8/8/20242640닷넷: 2294. C# 13 - (6) iterator 또는 비동기 메서드에서 ref와 unsafe 사용을 부분적으로 허용파일 다운로드1
13709정성태8/7/20242468닷넷: 2293. C# - safe/unsafe 문맥에 대한 C# 13의 (하위 호환을 깨는) 변화파일 다운로드1
13708정성태8/7/20242219개발 환경 구성: 719. ffmpeg / YoutubeExplode - mp4 동영상 파일로부터 Audio 파일 추출
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...