我有一个存储日期时间的实体,我使用JMSSerializer通过API返回此字段:
/**
* @ORM\Column(type="datetime")
*
* @Serializer\Type("DateTime<'d/m - H:i', 'Europe/Paris'>")
*/
private $creationDateTime;
在数据库中,creationDateTime与UTC时区一起存储。
更改格式正确应用于JSON API响应(例如,将“d / m H:i替换为d / m / YH:i”),但返回的时间始终是存储的(UTC一),而不是预计一个(欧洲/巴黎),即使我设置了一个完全不同的时区。
例如,如果存储的时间是15:04,则API返回的序列化时间仍为15:04(UTC),而不是预期的时间(16:04,欧洲/巴黎)。
在序列化响应时,有没有办法在存储日期应用时区?
提前致谢。
我使用:Symfony 4,JMS-SerializerBundle 3.1.0,JMS-Serializer 2.1.0
编辑:
在这里我做了一个循环,但绝对不是解决这个问题的最佳方法:
/**
* Returns the signal creation date and time
*
* @Serializer\Type(
* "DateTime<'d/m/Y H:i'>"
* )
*
* @Serializer\Groups({"signals"})
* @Serializer\VirtualProperty()
* @Serializer\Expose
*/
public function getCreationDateTime(): \DateTime
{
$dateTime = $this->creationDateTime;
$dateTime->setTimeZone(new \DateTimeZone("Europe/Paris"));
return $dateTime;
}
使其全球化的最佳方法是在以下位置配置它:
config> packages> jms_serializer.yaml
像这样:
jms_serializer:
handlers:
datetime:
default_format: "Y-m-d\\TH:i:sP" # ATOM
default_timezone: "UTC" # defaults to whatever timezone set in php.ini or via date_default_timezone_set
见doc,Extensions Reference部分