陈大剩博客

Laravel 7.0中 timestamp 取出来的时间慢的8小时问题

  • 陈大剩
  • 2020-07-09 21:27:49
  • 1567

部署博客后,评论的时间不正确,比正常时间慢了8小时;
都是用的 timestamp 字段存储的时间,只有评论留言取出来的时间慢的8小时,其他没有页面没有;
时区改成PRC、缓存也清了, 但是就是不生效;

出现原因

数据库中的时间:

数据库时间

取出的timestamp的时间:

timestamp

取出后转化成date的时间:

取出的时间

排查原因:

其他方法输出的时间没有问题;
原来是代码中进行了模型的toArray或者toJSON方法; 导致日期序列化格式不同

修复问题

在基类模型中写入如下方法:写入当前模型也行,切勿改框架基类(如果改基类 composer update 就会没有了)

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

其实Laravel 7.0升级说明中说了此问题:升级说明《Laravel 7 中文文档》(没有仔细看升级说明文档);

描述如下:

受影响可能性:高 在 Eloquent 模型上使用 toArraytoJson 方法时,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 的模型和模型集合,对数据库中的日期没有影响。

只要将此方法加入你的模型中就行,切记不要改模型基类源码(难以维护);

总结

是没有仔细看说明文档就开始撸代码了
一定注意多看文档

分享到:
0

说点儿什么吧

头像

表情
hello
hello

不看文档+1 >;br/>;>;br/>;之前遇到过 找源码解决的>;br/>;https://learnku.com/articles/43449

2020-07-13 13:31:22

本站由陈大剩博客程序搭建 | 湘ICP备17009938号| Copyright © 2017 - Laravel | 本站采用创作共用版权:CC BY-NC 4.0

站长统计| 文章总数[21]| 评论总数[10]| 登录用户[17]| 时间点[23]

登入

社交账号登录