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

(시리즈 글이 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




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)
13804정성태11/7/20247056Linux: 101. eBPF 함수의 인자를 다루는 방법
13803정성태11/7/20246638닷넷: 2309. C# - .NET Core에서 바뀐 DateTime.Ticks의 정밀도
13802정성태11/6/20247044Windows: 269. GetSystemTimeAsFileTime과 GetSystemTimePreciseAsFileTime의 차이점파일 다운로드1
13801정성태11/5/20246861Linux: 100. eBPF의 2가지 방식 - libbcc와 libbpf(CO-RE)
13800정성태11/3/20247841닷넷: 2308. C# - ICU 라이브러리를 활용한 문자열의 대소문자 변환 [2]파일 다운로드1
13799정성태11/2/20245616개발 환경 구성: 732. 모바일 웹 브라우저에서 유니코드 문자가 표시되지 않는 경우
13798정성태11/2/20247271개발 환경 구성: 731. 유니코드 - 출력 예시 및 폰트 찾기
13797정성태11/1/20247254C/C++: 185. C++ - 문자열의 대소문자를 변환하는 transform + std::tolower/toupper 방식의 문제점파일 다운로드1
13796정성태10/31/20246770C/C++: 184. C++ - ICU dll을 이용하는 예제 코드 (Windows)파일 다운로드1
13795정성태10/31/20245958Windows: 268. Windows - 리눅스 환경처럼 공백으로 끝나는 프롬프트 만들기
13794정성태10/30/20246045닷넷: 2307. C# - 윈도우에서 한글(및 유니코드)을 포함한 콘솔 프로그램을 컴파일 및 실행하는 방법
13793정성태10/28/20246009C/C++: 183. C++ - 윈도우에서 한글(및 유니코드)을 포함한 콘솔 프로그램을 컴파일 및 실행하는 방법
13792정성태10/27/20245401Linux: 99. Linux - 프로세스의 실행 파일 경로 확인
13791정성태10/27/20245859Windows: 267. Win32 API의 A(ANSI) 버전은 DBCS를 사용할까요?파일 다운로드1
13790정성태10/27/20245352Linux: 98. Ubuntu 22.04 - 리눅스 커널 빌드 및 업그레이드
13789정성태10/27/20246327Linux: 97. menuconfig에 CONFIG_DEBUG_INFO_BTF, CONFIG_DEBUG_INFO_BTF_MODULES 옵션이 없는 경우
13788정성태10/26/20245115Linux: 96. eBPF (bpf2go) - fentry, fexit를 이용한 트레이스
13787정성태10/26/20246480개발 환경 구성: 730. github - Linux 커널 repo를 윈도우 환경에서 git clone하는 방법 [1]
13786정성태10/26/20246263Windows: 266. Windows - 대소문자 구분이 가능한 파일 시스템
13785정성태10/23/20245604C/C++: 182. 윈도우가 운영하는 2개의 Code Page파일 다운로드1
13784정성태10/23/20246212Linux: 95. eBPF - kprobe를 이용한 트레이스
13783정성태10/23/20245724Linux: 94. eBPF - vmlinux.h 헤더 포함하는 방법 (bpf2go에서 사용)
13782정성태10/23/20245418Linux: 93. Ubuntu 22.04 - 커널 이미지로부터 커널 함수 역어셈블
13781정성태10/22/20245966오류 유형: 930. WSL + eBPF: modprobe: FATAL: Module kheaders not found in directory
13780정성태10/22/20247032Linux: 92. WSL 2 - 커널 이미지로부터 커널 함수 역어셈블
13779정성태10/22/20245606개발 환경 구성: 729. WSL 2 - Mariner VM 커널 이미지 업데이트 방법
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...