首页 > 代码库 > 异常处理

异常处理

异常处理

和PHP默认的异常处理不同,ThinkPHP抛出的不是单纯的错误信息,而是一个人性化的错误页面。

默认异常处理

在调试模式下,系统默认展示的错误页面:

技术分享

只有在调试模式下面才能显示具体的错误信息,如果在部署模式下面,你可能看到的是一个简单的提示文字,例如:

技术分享

本着严谨的原则,5.0版本默认情况下会对任何错误(包括警告错误)抛出异常,如果不希望如此严谨的抛出异常,可以在应用公共函数文件中或者配置文件中使用error_reporting方法设置错误报错级别(请注意,在入口文件中设置是无效的),例如:

// 异常错误报错级别,
error_reporting(E_ERROR | E_PARSE );

异常处理接管

框架支持异常页面由开发者自定义类进行处理,需要配置参数exception_handle

    // 异常处理handle类 留空使用 \think\exception\Handle
    ‘exception_handle‘       => ‘\\app\\common\\exception\\Http‘,

自定义类需要继承Handle并且实现render方法,可以参考如下代码:

<?php
namespace app\common\exception;

use Exception;
use think\exception\Handle;
use think\exception\HttpException;
class Http extends Handle
{

    public function render(Exception $e)
    {
        if ($e instanceof HttpException) {
            $statusCode = $e->getStatusCode();
        }
        //TODO::开发者对异常的操作
        //可以在此交由系统处理
        return parent::render($e);
    }

}

需要注意的是,如果配置了’exception_handle’,且没有再次调用系统render的情况下,配置http_exception_template就不再生效,具体可以参考Handle类内实现的功能。

部署模式异常

一旦关闭调试模式,发生错误后不会提示具体的错误信息,如果你仍然希望看到具体的错误信息,那么可以如下设置:

// 显示错误信息
‘show_error_msg‘        =>  true,    

技术分享

异常捕获

可以使用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(‘执行成功!‘);

 

手动抛出异常

可以使用\think\Exception类来抛出异常

// 使用think自带异常类抛出异常
throw new \think\Exception(‘异常消息‘, 100006);

如果不使用think异常类,也可以定义自己的异常类来抛出异常

throw new \foobar\Exception(‘异常消息‘);

也可以使用系统提供的助手函数来简化处理:

exception(‘异常消息‘, 100006);

// 使用自定义异常类
exception(‘异常消息‘, 100006, \foobar\Exceeption);

抛出 HTTP 异常

可以使用\think\exception\HttpException类来抛出异常

// 抛出 HTTP 异常
throw new \think\exception\HttpException(404, ‘异常消息‘, null, [参数]);

系统提供了助手函数abort简化HTTP异常的处理,例如:

abort(404, ‘异常消息‘, [参数])

HTTP异常可以单独定义异常模板,请参考后面的404页面。

异常处理