프로그래밍에서 시간대를 다루는 것은 까다로울 수 있습니다.
PHP는 웹용이므로 언어에서도 이를 지원합니다. 왜 관심을 가져야 하는지 살펴보겠습니다.
시간대에 신경쓰지 않으면 조만간 버그가 발생합니다.
시간 관련 기능이 실패할 수 있습니다(예: 예정된 이벤트). Daylight Time과 같은 까다로운 개념을 다루어야 한다면 상황은 더욱 악화됩니다.
전자상거래에 필수적인 개념은 다음과 같습니다.
모든 버그는 궁극적으로 비즈니스에 해를 끼칩니다.
가장 기본이지만 여전히 강력한 구현은 다음과 유사합니다.
$timeZone = new DateTimeZone('Europe/Berlin'); $date = new DateTime('now', $timeZone); echo $date->format('Y-m-d H:i:s');
내장된 DateTime 클래스는 DateTimeZone 개체를 두 번째 인수로 사용하며 이는 $date 개체를 사용한 추가 작업에 영향을 미칩니다.
적절한 시간대를 찾으려면 DateTimeZone::listIdentifiers() 또는 이 링크를 사용할 수 있습니다.
DateTime은 날짜에 대한 일반적인 작업을 실행하기 위한 다양한 도우미를 제공합니다. 시차는 매우 기본적인 것이지만, 시간대가 다르면 어떻게 되나요?
$dateTimeNY = new DateTime('2024-08-02 01:01:01', new DateTimeZone('America/New_York')); $dateTimeBerlin = new DateTime('2024-08-02 07:01:01', new DateTimeZone('Europe/Berlin')); $interval = $dateTimeNY->diff($dateTimeBerlin); print_r($interval);// 0 everywhere
'America/New_York' 및 'Europe/Berlin' 시간대가 없으면 PHP는 $dateTimeNY 및 $dateTimeBerlin이 기본적으로 동일한 시간대에 속한다고 가정하므로 또 다른 차이(6시간)를 얻게 됩니다.
여기에서는 당연해 보일 수도 있지만 앱이 해당 정보를 올바르게 캡처하지 않으면 나쁜 결과를 초래할 수 있습니다.
PHP에서 기본 시간대에 특정 값을 설정할 수 있지만 특히 관리할 시간대가 다른 경우에는 일반적으로 UTC를 사용하는 것이 더 좋습니다.
UTC는 "Unix Epoch"를 의미하며 보편적인 형식입니다.
99.9%의 경우 날짜를 UTC로 저장하는 것이 좋습니다.
이렇게 하면 일관성을 유지할 수 있습니다.
해당 데이터를 조작하려면 PHP 내장 도우미와 변환기를 사용해야 하지만 저장된 모든 데이터는 동일한 원본 지점(1970년 1월 1일 00:00:00 UTC)만 참조합니다.
비교 및 정렬과 같은 일반적인 작업이 쉬워집니다. 그렇지 않으면 동일해 보이지만 암시적으로 동일한 기준에 있지 않은 값이 생성될 수 있습니다.
GMT는 그리니치 표준시를 의미하며, 예전에는 시간대의 초석이었습니다.
기술적으로 말하면 UTC와 GMT는 같은 시간을 나타냅니다. 그러나 UTC가 더 정확하고(원자 시계) 더 일관적입니다(일광 절약 시간 없음).
UTC와 달리 GMT는 시간대입니다. 각 시간대가 GMT+0에서 시간을 더하거나 빼는 방식을 본 적이 있을 것입니다.
두 가지 모두 비슷한 목적을 위한 시간 기준이지만 UTC가 더 정교합니다.
다양한 출처에 따르면 "UTC"로 축약됩니다. 그렇지 않으면 영어로 "CUT"("협정 세계시"), 프랑스어로 "TUC"("Temps Universel Coordonné")가 되기 때문입니다.
줄루어는 주로 군사 및 항공 관련 업무에서 사용되는 시간 표준입니다.
'줄루(Zulu)'는 '경도 0 자오선'이라는 뜻으로 GMT와 거의 동일하지만, 군대와 비행사들은 문자 대신 표음 문자를 사용합니다.
UTC와 달리 중요한 개념은 아니지만 알아두면 좋습니다. 실제로 해당 형식이 필요한 경우 PHP에서 지원합니다.
Y-m-d\TH:i:sp
'시간대'라는 개념은 기계나 프로그램이 아닌 인간만을 위한 것입니다.
정부는 '시간 설정'을 수정할 수 있습니다. 예를 들어 UTC 오프셋이나 DST(일광 절약 시간) 준수 여부가 달라질 수 있습니다.
다른 많은 이벤트가 세계 시간에 영향을 미칠 수 있습니다. 프로그래밍 시 표준 시간대 작업을 위해 범용 형식 UTC 및 표준화된 변환기를 사용하는 또 다른 좋은 이유입니다.
Carbon은 기본 DateTime 객체 위에 구축된 도우미 세트입니다.
따라서 Carbon은 시간대를 지원합니다.
$tomorrow = Carbon::now()->tomorrow()->tz('Europe/Berlin');
Laravel과 같은 프레임워크를 사용한다면 Carbon 패키지가 이미 설치되어 있습니다.
일광 절약 시간 또는 일광 절약 시간(DST)은 많은 앱에서 중요한 개념입니다.
간단히 말하면 사람들은 일광을 더 잘 활용하기 위해 시계를 바꿉니다.
이런 현상은 일반적으로 여름에 일광이 더 길기 때문에 발생합니다(모든 지역이 그런 것은 아님). 그래서 사람들은 일광이 다시 짧아지는 가을에 시계를 앞당기고 시계를 다시 설정합니다.
즉, DST는 일출 및 일몰 시간과 관련이 있으며 이는 전 세계적으로 매우 다를 수 있습니다.
getTransitions()를 사용하여 이러한 변형을 검색할 수 있습니다.
$timezone = new DateTimeZone('Europe/Berlin'); $transitions = $timezone->getTransitions(); print_r($transitions);
If you use the latest version of PHP, you will not get this specific bug, but your case can be a known issue.
Read reported bugs and issues, as it might prevent some headaches.
위 내용은 PHP: 시간대 이해하기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!