laravel时间格式化引起的时区问题

laravel的时区设置为PRC或者Asia/Shanghai后,数据插入到数据库是,现实的时间是正常的,但是查询后却是不正常的,原因竟然是我在查询的时候把时间格式化的问题。

laravel默认的时间格式是这样的,如图:

laravel时间格式化引起的时区问题

为了修改这个格式,我在Model里做了配置:

    protected $casts = [
        'created_at'   => 'datetime:Y-m-d H:i:s',
        'updated_at'   => 'datetime:Y-m-d H:i:s',
    ];

但是我发现查询出的时间总是比实际时间少八个小时,而后翻阅了laravel官方的文档,文档是这么说的:

日期序列化
受影响可能性:高

在 Eloquent 模型上使用 toArray 或 toJson 方法时,Laravel 7 将使用新的日期序列化格式。为了格式化日期以进行序列化,Laravel 将会使用 Carbon 的 toJSON 方法,该方法将生成与 ISO-8601 兼容的日期,包括时区信息及小数秒。此外,该更改提供了更好的支持,并与客户端日期解析库集成。

此前,日期将序列化为以下格式:2020-03-04 16:11:00 。使用新格式进行序列化的日期将显示为:2020-03-04T20:01:00.283041Z

如果你希望继续保持之前所用的格式,你可以重写模型的 serializeDate 方法:

/**
 * 为数组 / JSON 序列化准备日期。
 *
 * @param  \DateTimeInterface  $date
 * @return string
 */
protected function serializeDate(DateTimeInterface $date)
{
    return $date->format($this->dateFormat ?: 'Y-m-d H:i:s');
}

还特意说明了,该更改仅影响序列化为数组和 JSON 的模型和模型集合,对数据库中的日期没有影响。

怪不得我的数据库里时间是正确的,查询出来就少八个小时,原来是laravel自带的组件导致的,还是得多看文档啊

上一篇:C语言清除输入缓冲区


下一篇:北航教授王田苗:中国机器人的发展机遇与挑战是什么?