异常处理

最后更新于:2022-04-01 21:24:40

和PHP默认的异常处理不同,ThinkPHP抛出的不是单纯的错误信息,而是一个人性化的错误页面。 ## 默认异常处理 在调试模式下,系统默认展示的错误页面: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/0ddddc3bcc3a3755e21542fd296b741f_1028x708.png) >[info]只有在调试模式下面才能显示具体的错误信息,如果在部署模式下面,你可能看到的是一个简单的提示文字,例如: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/a770f72a8ce4bab4352927ff8b69139f_817x162.png) >[danger]#### 本着严谨的原则,5.0版本默认情况下会对任何错误(包括警告错误)抛出异常,如果不希望如此严谨的抛出异常,可以在应用公共函数文件中或者配置文件中使用`error_reporting`方法设置错误报错级别(请注意,在入口文件中设置是无效的),例如: ~~~ // 异常错误报错级别, error_reporting(E_ERROR | E_PARSE ); ~~~ ## 异常处理接管 框架支持异常页面由开发者自定义类进行处理,需要配置参数`exception_handle` ~~~ // 异常处理handle类 留空使用 \think\exception\Handle 'exception_handle' => '\\app\\common\\exception\\Http', ~~~ 自定义类需要继承`Handle`并且实现`render`方法,可以参考如下代码: ~~~ getError(), 422); } // 请求异常 if ($e instanceof HttpException && request()->isAjax()) { return response($e->getMessage(), $e->getStatusCode()); } //TODO::开发者对异常的操作 //可以在此交由系统处理 return parent::render($e); } } ~~~ >[info]需要注意的是,如果配置了'exception_handle',且没有再次调用系统`render`的情况下,配置`http_exception_template`就不再生效,具体可以参考`Handle`类内实现的功能。 `V5.0.11`版本开始,可以通过闭包定义的方式简化异常自定义处理,例如,上面的自定义异常类可以改为直接配置`exception_handle`参数: ~~~ 'exception_handle' => function(Exception $e){ // 参数验证错误 if ($e instanceof \think\exception\ValidateException) { return json($e->getError(), 422); } // 请求异常 if ($e instanceof \think\exception\HttpException && request()->isAjax()) { return response($e->getMessage(), $e->getStatusCode()); } } ~~~ ## 部署模式异常 一旦关闭调试模式,发生错误后不会提示具体的错误信息,如果你仍然希望看到具体的错误信息,那么可以如下设置: ~~~ // 显示错误信息 'show_error_msg' => true, ~~~ ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/b4f2c9679d0b0803d963cf5b1253db96_839x191.png) ## 异常捕获 可以使用PHP的异常捕获进行必要的处理,但需要注意一点,在异常捕获中不要使用`think\Controller`类的error、success和redirect方法,因为上述三个方法会抛出`HttpResponseException`异常,从而影响正常的异常捕获,例如: ~~~ try{ Db::name('user')->find(); $this->success('执行成功!'); }catch(\Exception $e){ $this->error('执行错误'); } ~~~ 应该改成 ~~~ try{ Db::name('user')->find(); }catch(\Exception $e){ $this->error('执行错误'); } $this->success('执行成功!'); ~~~
';