Microsoft MVP성태의 닷넷 이야기
닷넷: 2143. C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법 [링크 복사], [링크+제목 복사],
조회: 4007
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법

아래와 같은 트윗이 떴군요. ^^


닷넷은 어떨까요? ^^

우선, 현재 시스템의 Time Zone은 TimeZoneInfo.Local을 이용해 구할 수 있습니다.

namespace ConsoleApp1;

internal class Program
{
    static void Main(string[] args)
    {
        while (true)
        {
            Console.WriteLine(TimeZoneInfo.Local); // TimeZone.CurrentTimeZone은 deprecated
            Thread.Sleep(1000);                
        }            
    }
}
/* 출력 결과
(UTC+09:00) Seoul
...[생략]...
*/

위와 같이 실행한 상태에서 Settings / "Time & language" 설정에 들어가 "Date & time"에서 "Time zone"을 바꾸면,

current_time_zone_1.png

콘솔 화면에는 여전히 "(UTC+09:00) Seoul"로 찍히는 것을 볼 수 있습니다.




아쉽게도, C# 역시 시스템의 Time zone에 대해 실시간 반영하는 방법은 없고, 대신에 공식 문서에도 나오듯이,

You should always access the local time zone through the TimeZoneInfo.Local property rather than assigning the local time zone to a TimeZoneInfo object variable. This prevents the TimeZoneInfo object variable from being invalidated by a call to the ClearCachedData method.


필요한 경우 ClearCachedData를 호출해야 합니다. 따라서 다음과 같이 코드를 바꾸면,

namespace ConsoleApp1;

internal class Program
{
    static void Main(string[] args)
    {
        while (true)
        {
            Console.WriteLine($"{TimeZoneInfo.Local}");
            TimeZoneInfo.ClearCachedData();

            Thread.Sleep(1000);                
        }            
    }
}

/* 출력 결과:
(UTC+09:00) Seoul
...[생략]...
(UTC+09:30) Adelaide
...[생략]...
*/

중간에 시스템의 Time Zone 변화를 반영하는 것을 볼 수 있습니다. 사실, 파이썬의 경우에도 Time Zone의 변경에 대한 알림을 받는 것은 아닐 것이므로 어차피 위의 코드와 비교해 그다지 차이가 없다고 봐야 할 것입니다.

참고로, Settings에서 변경한 Time Zone 정보는 레지스트리에 곧바로 반영됩니다.

Computer\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\TimeZoneInformation

// 서울인 경우
current_time_zone_2.png

// Adelaide인 경우
current_time_zone_3.png

따라서, 정말로 "알림"을 받는 식으로 처리해야 한다면 윈도우의 경우 레지스트리 알림 기능을 이용해,

C# - 특정 레지스트리 변경 시 알림을 받는 방법
; https://www.sysnet.pe.kr/2/0/12621

이런 식으로 처리할 수는 있습니다.

using Microsoft.Win32;
using System.Management;

namespace ConsoleApp1;

// Nuget 패키지 참조
// Install-Package System.Management
internal class Program
{
    static void Main(string[] args)
    {
        Console.WriteLine($"{TimeZoneInfo.Local}");

        using (RegistryMonitor regMon = new RegistryMonitor(Registry.LocalMachine,
           @"SYSTEM\\CurrentControlSet\\Control\\TimeZoneInformation"))
        {
            regMon.Changed += registry_Changed;

            do
            {
                Console.WriteLine("Press 'q' key to exit...");
            } while (Console.ReadLine() != "q");
        }
    }

    private static void registry_Changed(object sender, EventArrivedEventArgs e)
    {
        TimeZoneInfo.ClearCachedData();
        Console.WriteLine($"{TimeZoneInfo.Local}");
    }
}

public class RegistryMonitor : IDisposable
{
    // 참고: https://www.sysnet.pe.kr/2/0/12621
}

(아쉽게도 Time Zone 변경에 대해 SystemParametersInfo Win32 API를 사용하지 않는 듯합니다. 그런 탓에 WM_SETTINGCHANGE 알림은 발생하지 않습니다.)




마지막으로, 윈도우의 Shell Prompt 명령어로는 tzutil을 사용할 수 있습니다.

Windows - Time zone 설정을 바꿔도 반영이 안 되는 경우
; https://www.sysnet.pe.kr/2/0/12337





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

[연관 글]






[최초 등록일: ]
[최종 수정일: 10/26/2023]

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)
12222정성태6/3/202010359VS.NET IDE: 146. error information: "CryptQueryObject" (-2147024893/0x80070003)
12221정성태6/3/202010096Windows: 170. 비어 있지 않은 디렉터리로 symbolic link(junction) 연결하는 방법
12220정성태6/3/202012592.NET Framework: 907. C# DLL로부터 TLB 및 C/C++ 헤더 파일(TLH)을 생성하는 방법
12219정성태6/1/202011677.NET Framework: 906. C# - lock (this), lock (typeof(...))를 사용하면 안 되는 이유파일 다운로드1
12218정성태5/27/202011629.NET Framework: 905. C# - DirectX 게임 클라이언트 실행 중 키보드 입력을 감지하는 방법 [3]
12217정성태5/24/202010057오류 유형: 615. Transaction count after EXECUTE indicates a mismatching number of BEGIN and COMMIT statements. Previous count = 0, current count = 1.
12216정성태5/15/202013242.NET Framework: 904. USB/IP PROJECT를 이용해 C#으로 USB Keyboard 가상 장치 만들기 [14]파일 다운로드1
12215정성태5/12/202018346개발 환경 구성: 490. C# - (Wireshark의) USBPcap을 이용한 USB 패킷 모니터링 [10]파일 다운로드1
12214정성태5/5/202010608개발 환경 구성: 489. 정식 인증서가 있는 경우 Device Driver 서명하는 방법 (2) - UEFI/SecureBoot [1]
12213정성태5/3/202012272개발 환경 구성: 488. (User-mode 코드로 가상 USB 장치를 만들 수 있는) USB/IP PROJECT 소개
12212정성태5/1/20209897개발 환경 구성: 487. UEFI / Secure Boot 상태인지 확인하는 방법
12211정성태4/27/202012227개발 환경 구성: 486. WSL에서 Makefile로 공개된 리눅스 환경의 C/C++ 소스 코드 빌드
12210정성태4/20/202012681.NET Framework: 903. .NET Framework의 Strong-named 어셈블리 바인딩 (1) - app.config을 이용한 바인딩 리디렉션 [1]파일 다운로드1
12209정성태4/13/202010711오류 유형: 614. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우 (2)
12208정성태4/12/202010133Linux: 29. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우
12207정성태4/2/20209119스크립트: 19. Windows PowerShell의 NonInteractive 모드
12206정성태4/2/202011438오류 유형: 613. 파일 잠금이 바로 안 풀린다면? - The process cannot access the file '...' because it is being used by another process.
12205정성태4/2/20208796스크립트: 18. Powershell에서는 cmd.exe의 명령어를 지원하진 않습니다.
12204정성태4/1/20208629스크립트: 17. Powershell 명령어에 ';' (semi-colon) 문자가 포함된 경우
12203정성태3/18/202010708오류 유형: 612. warning: 'C:\ProgramData/Git/config' has a dubious owner: '...'.
12202정성태3/18/202013258개발 환경 구성: 486. .NET Framework 프로젝트를 위한 GitLab CI/CD Runner 구성
12201정성태3/18/202011086오류 유형: 611. git-credential-manager.exe: Using credentials for username "Personal Access Token". [1]
12200정성태3/18/202011473VS.NET IDE: 145. NuGet + Github 라이브러리 디버깅 관련 옵션 3가지 - "Enable Just My Code" / "Enable Source Link support" / "Suppress JIT optimization on module load (Managed only)"
12199정성태3/17/20209294오류 유형: 610. C# - CodeDomProvider 사용 시 Unhandled Exception: System.IO.DirectoryNotFoundException: Could not find a part of the path '...\f2_6uod0.tmp'.
12198정성태3/17/202012097오류 유형: 609. SQL 서버 접속 시 "Cannot open user default database. Login failed."
12197정성태3/17/202011238VS.NET IDE: 144. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 - 두 번째 이야기 [1]
... 46  47  48  49  50  51  52  53  54  55  56  [57]  58  59  60  ...