微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

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自带的组件导致的,还是得多看文档啊

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。