在我的项目中,我有一些createdAt
列的实体。
//...
class Acme
{
/**
* @var DateTime
*
* @ORM\Column(name="created_at", type="datetime")
*/
protected $createdAt;
}
我已使用Symfony序列化程序启用FOSRestBundle
:
fos_rest:
disable_csrf_role: ROLE_API
param_fetcher_listener: true
body_listener: true
format_listener:
rules:
- { path: '/', fallback_format: json, prefer_extension: false }
routing_loader:
default_format: json
include_format: false
view:
view_response_listener: force
我从AcmeRepository
中的datebase中选择:
public function methodName()
{
$qb = $this->createQueryBuilder('d');
$s = $qb->select('d.createdAt']);
return $s->getQuery()->getArrayResult();
}
结果,在我的控制器中:
$res = $em->getRepository('AppBundle:Acme')->methodName();
return $res;
它会返回json,但不是[{"created_at": "2016-04-04 12:13:13"}]
我得到了这个:
[{"created_at":{"timezone":{"name":"UTC","location":{"country_code":"??","latitude":0,"longitude":0,"comments":""}},"offset":0,"timestamp":1459769277}]
我如何解决这个问题?
答案 0 :(得分:4)
您可以使用正确的注释类型指定为FOS REST模块定义的类型的格式(选中here doc)。例如:
use JMS\Serializer\Annotation\Type as JMS;
class Acme
{
/**
* @var DateTime
*
* @ORM\Column(name="created_at", type="datetime")
* @JMS\Type("DateTime<'Y-m-d'>")
*/
protected $createdAt;
}
希望这个帮助