PHPerKaigi 2025

Интерфейс DateTimeInterface

(PHP 5 >= 5.5.0, PHP 7, PHP 8)

Введение

Интерфейс DateTimeInterface создали так, чтобы объявления типов параметров, значений возврата или свойств принимали как значение объекты классов DateTimeImmutable и DateTime. Невозможно реализовать интерфейс в пользовательских классах.

В интерфейсе также определили общие константы, которые разрешают форматировать объекты классов DateTimeImmutable и DateTime методами DateTimeImmutable::format() и DateTime::format().

Обзор интерфейса

interface DateTimeInterface {
/* Константы */
public const string ATOM = "Y-m-d\\TH:i:sP";
public const string COOKIE = "l, d-M-Y H:i:s T";
public const string ISO8601 = "Y-m-d\\TH:i:sO";
public const string ISO8601_EXPANDED = "X-m-d\\TH:i:sP";
public const string RFC822 = "D, d M y H:i:s O";
public const string RFC850 = "l, d-M-y H:i:s T";
public const string RFC1036 = "D, d M y H:i:s O";
public const string RFC1123 = "D, d M Y H:i:s O";
public const string RFC7231 = "D, d M Y H:i:s \\G\\M\\T";
public const string RFC2822 = "D, d M Y H:i:s O";
public const string RFC3339 = "Y-m-d\\TH:i:sP";
public const string RFC3339_EXTENDED = "Y-m-d\\TH:i:s.vP";
public const string RSS = "D, d M Y H:i:s O";
public const string W3C = "Y-m-d\\TH:i:sP";
/* Методы */
public diff(DateTimeInterface $targetObject, bool $absolute = false): DateInterval
public format(string $format): string
public getOffset(): int
public getTimestamp(): int
public __wakeup(): void
}

Предопределённые константы

DateTimeInterface::ATOM string
DATE_ATOM
Дата и время в формате стандарта Atom: 2005-08-15T15:52:01+00:00
DateTimeInterface::COOKIE string
DATE_COOKIE
Дата и время для установки с блоках данных cookies HTTP-протокола: Monday, 15-Aug-05 15:52:01 UTC
DateTimeInterface::ISO8601 string
DATE_ISO8601
Дата и время по стандарту ISO-8601: 2005-08-15T15:52:01+0000

Замечание: Формат несовместим с форматом стандарта ISO-8601, но остаётся по соображениям обратной совместимости. Вместо него используйте DateTimeInterface::ISO8601_EXPANDED или DateTimeInterface::ATOM для совместимости с ISO-8601. (ссылка на ISO8601:2004 раздел 4.3.3 пункт d)

DateTimeInterface::ISO8601_EXPANDED string
DATE_ISO8601_EXPANDED
Дата и время по стандарту ISO-8601 Expanded: +10191-07-26T08:59:52+01:00

Замечание: За счёт включения знакового символа формат принимает диапазоны лет за пределами нормального диапазона стандарта ISO-8601 — 0000-9999. Это гарантирует, что часть часового пояса вида +01:00 совместима со стандартом ISO-8601.

DateTimeInterface::RFC822 string
DATE_RFC822
Дата и время по стандарту RFC 822: Mon, 15 Aug 05 15:52:01 +0000
DateTimeInterface::RFC850 string
DATE_RFC850
Дата и время по стандарту RFC 850: Monday, 15-Aug-05 15:52:01 UTC
DateTimeInterface::RFC1036 string
DATE_RFC1036
Дата и время по стандарту RFC 1036: Mon, 15 Aug 05 15:52:01 +0000
DateTimeInterface::RFC1123 string
DATE_RFC1123
Дата и время по стандарту RFC 1123: Mon, 15 Aug 2005 15:52:01 +0000
DateTimeInterface::RFC7231 string
DATE_RFC7231
Дата и время по стандарту RFC 7231 с версии PHP 7.0.19 и 7.1.5: Sat, 30 Apr 2016 17:52:13 GMT
DateTimeInterface::RFC2822 string
DATE_RFC2822
Дата и время по стандарту RFC 2822: Mon, 15 Aug 2005 15:52:01 +0000
DateTimeInterface::RFC3339 string
DATE_RFC3339
То же, что и DATE_ATOM
DateTimeInterface::RFC3339_EXTENDED string
DATE_RFC3339_EXTENDED
Дата и время по стандарту RFC 3339 EXTENDED: 2005-08-15T15:52:01.000+00:00
DateTimeInterface::RSS string
DATE_RSS
Дата и время в RSS-формате: Mon, 15 Aug 2005 15:52:01 +0000
DateTimeInterface::W3C string
DATE_W3C
Дата и время в формате W3C (англ. World Wide Web Consortium): 2005-08-15T15:52:01+00:00

Список изменений

Версия Описание
8.4.0 Константы класса стали типизированными.
8.2.0 Добавили константу DateTimeInterface::ISO8601_EXPANDED .
7.2.0 Константы класса DateTime теперь определяются в интерфейсе DateTimeInterface.

Содержание

Добавить

Примечания пользователей 1 note

up
5
bohwaz
2 years ago
Please note that if you are using DATE_RFC7231 format (used in HTTP/1.1), you'll need to change the DateTime object timezone to GMT *before*, or you'll encounter weird results, as this format DOES NOT convert the date to GMT.

So if you have a DateTime object using UTC+01:00 as its timezone, you will get a difference of 1 hour between your resulting date string and what should be the "correct" date.

Recommended use:

<?php
$date_gmt
= clone $date;
$date_gmt->setTimezone(new \DateTimeZone('GMT'));
echo
$date_gmt->format(DATE_RFC7231);
?>
To Top