使用ManyToMany关系序列化doctrine对象

时间:2018-05-12 13:15:48

标签: symfony doctrine-orm pagerfanta

我正在尝试通过遵循symfony官方文档将对象序列化为json。 我得到了Pagerfanta对象(就像在Demo Application中一样从存储库中获取)

    public function findOneIncRel(int $page = 1): Pagerfanta
    {
        $query = $this->createQueryBuilder('b')
            ->select('b, m, a')
            ->leftJoin('b.marks', 'm')
            ->leftJoin('b.authors', 'a')
            ->getQuery();
        return $this->createPaginator($query, $page);
    }

    private function createPaginator(Query $query, int $page): Pagerfanta
    {
        $paginator = new Pagerfanta(new DoctrineORMAdapter($query));
        $paginator->setMaxPerPage(10);
        $paginator->setCurrentPage($page);

        return $paginator;
    }

我需要将结果转换为JSON。

我试过这个:

$books = $bookRepository->findAllIncRel(1);
$encoder = array(new JsonEncoder());
$normalizers = array(new ObjectNormalizer());
$normalizers[0]->setCircularReferenceLimit(1);
$normalizers[0]->setCircularReferenceHandler(function ($object) {
    return $object->getId();
});
$serializer = new Serializer($normalizers, $encoder);
return new JsonResponse($serializer->serialize($books->getCurrentPageResults(), 'json'));

Book的实例结构如下:

-id: ...
-marks: PersistentCollection ...
-authors: PersistentCollection ...
...

但所有我得到的都是无法捕获的500错误或“超过30秒的最大执行时间” 我不知道这里有什么问题。有没有其他方法来序列化PagerFanta对象?

祝你好运!

0 个答案:

没有答案