Yii 显示错误信息(Fatal Error,Warning)在页面上

来源:互联网 发布:mac代理设置 编辑:程序博客网 时间:2024/05/29 15:12

Yii由于设计上对于一些php奇怪问题的顾虑,并没有像cake,kohana一样把php错误信息打印在页面上。

遇到错误时,只是显示白页,这让没有经验的programmer会一头雾水。

实际上通常vhost上会开启php错误记录,放在根目录下的error_log里,但是需要FTP才可以查看,没有网页那么直观简便。


如果要在网页上显示php错误信息,可以自己定义shutdown处理。

具体如下:

1、创建一个CWebApplication派生类WebApp

<?phpclass WebApp extends CWebApplication{    public function __construct($config=null)    {        parent::__construct($config);        register_shutdown_function(array($this, 'print_err'));    }    public function print_err()    {        if (YII_ENABLE_ERROR_HANDLER && ($error = error_get_last())) {            $this->handleError($error['type'], $error['message'], $error['file'], $error['line']);            die();        }    }}

其中注册了错误处理函数print_err,调用error_get_last可获取到错误信息。


2、在index.php中作如下修改:

// Yii::createWebApplication($config)->run();    require_once 'protected/base/WebApp.php';Yii::createApplication('WebApp', $config)->run();

这样如果你遇到类没有定义,文件不存在等错误时,提示信息会直接显示在浏览器页面上。


iefreer


原创粉丝点击