500 系统错误处理器

Edit This Page

出问题了!你并不能预知错误,但你可以预料到。每个 Slime 框架应用程序都有一个错误处理器用于接收所有未抓取的 PHP 异常。这个错误处理器同样能接收当前 HTTP 的请求对象和响应对象。这个错误处理器必须预备并返回一个适当的响应对象,这个对象会被返回到 HTTP 客户端。

默认的错误处理器

默认的错误处理器非常基础。它将响应状态编码设置为 500,并将响应内容类型设置为 text/html,并将一个通用的错误信息加入到响应体中。

这个对于生产应用大概不太合适。强烈建议你实现专用于你的 Slim 应用程序的错误处理器。

默认的错误处理程序还可以包括详细的错误诊断信息。要启用这个功能你需要将 displayErrorDetails 设置为 true :

  1. $configuration = [
  2. 'settings' => [
  3. 'displayErrorDetails' => true,
  4. ],
  5. ];
  6. $c = new \Slim\Container($configuration);
  7. $app = new \Slim\App($c);

自定义错误处理器

Slim 框架应用程序的错误处理器是一种 Pimple 服务。你可以通过应用程序容器对自定义 Pimple factory 方法进行定义,来创建自定义的错误处理器取代默认的。

有两种注入处理器的方法:

Pre App

  1. $c = new \Slim\Container();
  2. $c['errorHandler'] = function ($c) {
  3. return function ($request, $response, $exception) use ($c) {
  4. return $c['response']->withStatus(500)
  5. ->withHeader('Content-Type', 'text/html')
  6. ->write('Something went wrong!');
  7. };
  8. };
  9. $app = new \Slim\App($c);

Post App

  1. $app = new \Slim\App();
  2. $c = $app->getContainer();
  3. $c['errorHandler'] = function ($c) {
  4. return function ($request, $response, $exception) use ($c) {
  5. return $c['response']->withStatus(500)
  6. ->withHeader('Content-Type', 'text/html')
  7. ->write('Something went wrong!');
  8. };
  9. };

在这个例子中,我们定义了一个新的 errorHandler factory ,它将返回一个 callable 。返回的 callable 接收三个参数:

  • 一个 \Psr\Http\Message\ServerRequestInterface 实例
  • 一个 \Psr\Http\Message\ResponseInterface 实例
  • 一个 \Exception 实例这个 callable 必须 返回一个新的 \Psr\Http\Message\ResponseInterface 实例,对于给定的异常也是如此。

务必注意:下面这三个类型的异常不会被自定义的 errorHandler 处理:

  • Slim\Exception\MethodNotAllowedException: 这个可以用自定义的 notAllowedHandler 来处理。
  • Slim\Exception\NotFoundException: 这个可以用自定义的 notFoundHandler 来处理。
  • Slim\Exception\SlimException: 这种类型的异常是 Slim 内置的,它的处理不能被覆写。

禁用

要想彻底地禁用 Slim 的错误处理器,只需从容器中移除错误处理器即可:

  1. unset($app->getContainer()['errorHandler']);

现在,你需要负责处理所有异常了,因为 Slim 已经不再处理它们。