部署博客后,评论的时间不正确,比正常时间慢了8小时;
都是用的 timestamp 字段存储的时间,只有评论留言取出来的时间慢的8小时,其他没有页面没有;
时区改成PRC、缓存也清了, 但是就是不生效;
出现原因
数据库中的时间:
取出的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 模型上使用 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 的模型和模型集合,对数据库中的日期没有影响。
只要将此方法加入你的模型中就行,切记不要改模型基类源码(难以维护);
总结
是没有仔细看说明文档就开始撸代码了;
一定注意多看文档;