Symfony2 Controller不会捕获异常

时间:2011-04-16 20:30:29

标签: php doctrine-orm symfony

这是我删除操作的路由处理程序。只要该项目没有任何关联,它就能很好地工作。

public function projectDeleteAction()
{
    try {
        $request = $this->get('request');
        $my_id = $request->query->get('id');

        $em = $this->get('doctrine.orm.entity_manager');

        $item = $em->find('MyBundle:Main', $my_id);

        $em->remove($item);
        $em->flush();

        $info = $item->getName();
        $result = 0;
    }
    catch (Exception $e) {
        $info = toString($e);
        $result = -1;
    }

    return $this->render('MyBundle:Main:response.xml.twig',
            array('info' => $info, 'result' => $result ));
}

我已经解决了尝试删除带关联的项的错误,但是通过这个过程,“flush”抛出了PDOException。我尝试了各种方法来捕获它,但它似乎被Symfony2内部捕获,然后它响应HTTP 500错误。有没有办法可以让Symfony2无法捕捉到它,以便我可以处理它?这是一个使用AJAX的XML响应,因此我只想在上面发送错误代码。

3 个答案:

答案 0 :(得分:78)

如果您未在use语句中将Exception指定为\Exception,请尝试更改PDOExceptionException。 PHP尝试查找\YourNamespaceWithController\Exception而不是\Exception

答案 1 :(得分:9)

最好抓住你真正想要捕获的异常。在这个示例中,可能是Doctrine / DBAL / DBALException和/或Doctrine / DBA / DBAException。

因此

catch (Doctrine\DBAL\DBALException $e) {
  $result = -1;
};

我会建议做类似的事情:

    } catch (\Exception $e) {
        switch (get_class($e)) {
            case 'Doctrine\DBAL\DBALException':
                echo "DBAL Exception<br />";
                break;
            case 'Doctrine\DBA\DBAException':
                echo "DBA Exception<br />";
                break;
            default:
                throw $e;
                break;
        }
    }

这实际上捕获了数据库异常,如果由于某种原因发生了其他异常,则会将其重新引入Symfony2。

答案 2 :(得分:0)

我必须执行以下操作,这可能会对某些用户有所帮助;

try{
    $this->doctrine->em->persist($user);
    $this->doctrine->em->flush();
}catch(Exception $e){
    if($e->getPrevious()->getCode() == 23505){
        //handle duplicate error, 23505 is for postgres, 23000 is mysql unique constraint.    
    }
}