i18nFormat 中缺少时区

Timezone Missing In i18nFormat

在将我们的应用程序迁移到 PHP 7.2 后,我遇到了一个奇怪的问题,让时区显示在 CakePHP 3.5 中 Time/FrozenTime 对象的 JSON 结果中和一个新的服务器环境。

格式化新 Cake\I18n\Time 时会出现一个简化示例,如下所示:

(new Time())->i18nFormat("yyyy-MM-dd'T'HH:mm:ssxxx")

以前这会 return 一个像这样的字符串:

2020-01-31T10:57:43-07:00

但是在我们的新环境中,相同的代码无法 return 时区部分 ,而是 returning 结果如下:

2020-01-31T10:57:43

在内部,追踪 i18nFormat 一直到 Cake\I18n\DateFormatTrait::_formatObject,它们似乎都将完全相同的参数调用到 datefmt_create:

static::$_formatters[$key] = datefmt_create(
    'America/Denver',
    0,
    0,
    'America/Denver',
    1,
    'yyyy-MM-dd\'T\'HH:mm:ssxxx');

但这似乎return不同的结果,"xxx"部分没有效果。

是否有一些环境设置会对此产生影响?还是其他原因引起的?

如何取回时区部分?

它看起来像是 AWS Beanstalk 中 PHP 服务器的默认版本,Amazon Linux/2.9.2,仅原生支持 ICU 版本 50.1.2-11.12 - 它似乎不支持任何时区格式的 "x" 或 "X" 字符串。

我现在找到了一个不错的解决方法 - 只需使用旧的 "Z" 字符串,为 Cake 的时间和日期对象设置默认 JSON 格式:

config/bootstrap.php中:

$customFormat = "yyyy-MM-dd'T'HH:mm:ssZ";
\Cake\I18n\Time::setJsonEncodeFormat($customFormat); // For any mutable DateTime
\Cake\I18n\FrozenTime::setJsonEncodeFormat($customFormat);  // For any immutable DateTime

这不会给出 相同的 结果,但它仍然是一种可接受的 ISO8601 格式,其中包含时区(例如 2020-01-31T10:57:43-0700)并且按原样支持javascript 的日期 class.