2011-04-16 80 views
24

这是我的删除操作的路由处理程序。只要项目没有任何关联,它就可以很好地工作。Symfony2控制器不会发生异常

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响应,所以我宁愿只发送一个错误代码。

回答

76

尝试更改Exception\Exception如果您在使用说明中没有将PDOException指定为Exception。 PHP试图找到\YourNamespaceWithController\Exception而不是\Exception

+1

谢谢!就是这样。 – sleeves 2011-04-18 11:41:33

+0

我也是,感谢它! – 2015-10-13 17:30:14

8

最好赶上你真正想要捕捉的异常。在这个例子中,可能是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; 
     } 
    } 

这实际上捕获DB异常,如果由于某种原因,一些其他异常occures,这个被重新抛出回Symfony2的。

1

我不得不做下面这可能有助于一些用户;

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.  
    } 
}