Symfony2 Doctrine - 在kernel.response监听器中刷新刷新坏数据

时间:2015-01-18 22:05:52

标签: symfony doctrine listener flush

为了对我的Symfony2应用程序进行一些日志记录,我创建了一个记录任何连接的服务,这里是在kernel.response上调用的方法:

public function log(FilterResponseEvent $event)
{
    $log = new Log();
    $request = $event->getRequest();
    $response = $event->getResponse();
    //fill the Log entity with stuff from request & response data

    $manager = $this->container->get('doctrine.orm.entity_manager');
    $manager->persist($log);
    $manager->flush();
}

所有这一切似乎都很好,但是当我执行像这样的测试时(带有空数据的补丁触发失败):

$this->client->request(
    'PATCH', 
    '/users/testificate', 
    array(
        'firstName' => '',
    )
);

调用此操作:

protected function processForm($item, $method = 'PATCH')
{
    $form = $this->createForm(new $this->form(), $item, array('method' => $method));
    $form->handleRequest($this->getRequest());

    if ($form->isValid()) {
        $response = new Response();

        // Set the `Location` header only when creating new resources
        if ($method == 'POST') {
            $response->setStatusCode(201);
            $response->headers->set('Location',
                $this->generateUrl(
                    'get_' . strtolower($class), array('slug' => $item->getId()),
                    true // absolute
                )
            );
        }
        else {
            $response->setStatusCode(204);
        }
        $this->em->flush();

        return $response;
    }
    $this->em->detach($item);
    return RestView::create($form, 400);
}

虽然测试失败,但实体已修补,当然不能。 经过一些搜索,我所学到的是:

  • 参数输入表单验证器
  • 验证失败,因此返回400 http代码而不刷新实体
  • 但是在验证过程中,实体会使用无效数据进行补充
  • 在kernel.response上调用服务时,$ manager-> flush();刷新所有数据...包括PATCH测试提供的错误数据。

到目前为止我尝试过的事情: 1)做一个$ manager-> clear();在$ manager-> persist()之前; ......没有改变任何事情 2)做一个$ manager->分离($ item);如果表单验证失败...不会改变任何内容

谢谢!

1 个答案:

答案 0 :(得分:0)

在从Doctrine 2.3.4升级到最新的2.4分支时,我最近偶然发现了kernel.response中的刷新问题。尝试从kernel.terminate刷新日志实体。在kernel.response

中保留对响应的任何修改