很抱歉这个模糊的标题,我不知道如何标题我的问题。
我通过kernel.event_listener
服务监听kernel.exception
。我在我的API中使用它来捕获所有异常并在JSON中序列化它们,以便为API客户提供干净的错误处理。我必须根据异常类型(我的HTTP异常、Symfony HTTP异常等)调整序列化。
如果用户在访问security.yml中受access_control
限制的部分时未经过身份验证,Symfony将抛出非HTTP Symfony\Component\Security\Core\Exception\InsufficientAuthenticationException
。在我的序列化程序中,非HTTP异常被转换为500错误。因为InsufficientAuthenticationException
是一个401未授权的错误,所以我必须单独捕获这个异常,并将其转换为我的应用程序特定的异常类型。
示例:
# Find appropriate serialization
if($ex instanceof HttpErr\HttpErrorInterface) {
# AppBundle\Exceptions\Http\*
# A displayable error thrown intentionally by our controllers
$status = $ex->getStatusCode();
$message = $ex->getMessage();
$other = $ex->getAdditionalDatas();
} elseif($ex instanceof InsufficientAuthenticationException) {
throw new HttpErr\EUnauthorized; # look a this line
}
# more elseifs...
这是可行的。捕获Symfony身份验证异常,然后将其转换为EUnauthorized,然后将EUnauthorized序列化为JSON。但是您可以看到,我抛出了没有消息或previous
异常的异常。因为我想这么做:
elseif($ex instanceof InsufficientAuthenticationException) {
# the standard argument $previous is in 2nd position in my exceptions instead of being 3rd.
# the previous argument is important for me since it will keep context in error propagation.
throw new HttpErr\EUnauthorized($ex->getMessage(), $ex);
}
当我这样做时(所以,只需添加两个参数),序列化停止工作,我的事件侦听器没有被调用,应用程序崩溃(在prod中,这将变成一个友好的WSoD):
为什么?
发布于 2019-06-24 09:00:37
我不知道它在这里是否有帮助,但我遇到了类似的问题,我的事件侦听器没有被调用,应用程序崩溃。因此我解决了这个问题,并覆盖了Kernel.php文件中的一个方法,如下所示:
protected function initializeContainer() {
try {
$container = parent::initializeContainer();
} catch (\Throwable $throwable){
// MY CATCH CODE GOES HERE
}
return $container;
}
您还可以连接到其他内核方法并覆盖它们。
注意:我使用的是Symfony 4.2。*
https://stackoverflow.com/questions/32089673
复制相似问题