Symfony 4.1.6, при сериализации объекта класса обнаружена циклическая ссылка - PullRequest
0 голосов
/ 31 октября 2018

При сериализации сущности, которая имеет отношение к другому энтейту.

A circular reference has been detected when serializing the object of class происходит, если вы не установите setCircularReferenceLimit и setCircularReferenceHandler.

Это исправило проблему до symfony3.2, но теперь происходит Symofony4.1.6, Error: Maximum execution time of 30 seconds exceeded и время ожидания.

Где я должен проверить ????

$encoders = array(new XmlEncoder(), new JsonEncoder());
$norm = new ObjectNormalizer();

//// it fixes the problem before Symfony 3.2, but no it causes timeout
$norm->setCircularReferenceLimit(0);
$norm->setCircularReferenceHandler(function ($object) {
     return $object->getId();
});
//////////

$normalizers = array($norm);
$serializer = new Serializer($normalizers, $encoders);

/// get entity from doctorine2//
$myEntity = .... 

$jsonContent = $serializer->serialize($myEntity, 'json');

Моя ошибка

in vendor/symfony/property-access/PropertyAccessor.php (line 372)

    $result = self::$resultProto;        
    $object = $zval[self::VALUE];        
    $access = $this->getReadAccessInfo(\get_class($object), $property); 

    if (self::ACCESS_TYPE_METHOD === $access[self::ACCESS_TYPE]) {            
    $result[self::VALUE] = $object->{$access[self::ACCESS_NAME]}();
    } elseif (self::ACCESS_TYPE_PROPERTY === $access[self::ACCESS_TYPE]) {            
        $result[self::VALUE] = $object->{$access[self::ACCESS_NAME]};


    if ($access[self::ACCESS_REF] && isset($zval[self::REF])) {                
    $result[self::REF] = &$object->{$access[self::ACCESS_NAME]};
...