`
zccst
  • 浏览: 3330511 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

YII异常处理actionError

    博客分类:
  • YII
阅读更多
zccst转

错误处理目录
1,引发异常
2,显示错误
3,使用一个动作来处理错误
4,消息记录

Yii提供了一个完整的,基于PHP5异常处理的错误处理机制。当一个应用开始运行,进行用户请求的处理的时候,会注册handleError方法来处理PHP warnings和notices信息;同时也注册加handleException方法来处理未被捕获的PHP异常。因此,如果在应用运行期间出现一个PHP warning/notice 或者一个未捕获的PHP异常,错误处理器就会接过控制权来运行必要的处理机制。

提示: 错误处理器的注册是在应用中的constructor方法中进行的,使用了PHP函数set_exception_handler 和set_error_handler。 如果你不想让Yii来处理错误和异常,你可以在入口文件中定义YII_ENABLE_ERROR_HANDLER和YII_ENABLE_EXCEPTION_HANDLER为false.

默认情况下,在触发onError事件(或onException事件)的时候,errorHandler(或exceptionHandler)将被触发。如果错误或者异常未被任何事件所处理,那么就需要运行errorHandler组件来处理了。

1. 引发异常
在Yii中引发异常和在普通PHP文件中没什么两样。你可以使用下面的代码来抛出异常:

throw new ExceptionClass('错误信息');
Yii定义了两个异常类:CException和CHttpException。前者是一个通用的异常类,而后者用于对最终用户显示异常信息。同时,后者有一个statusCode属性来代表HTTP状态码。异常的类型决定了显示效果,下面会细说。

提示: 想要告诉用户某个操作是错误的,那么引发一个CHttpException异常是最简单的方法了。比如说,如果用户在URL中提供了一个无效的ID值,我们可以显示一个404错误:
// 如果提交的ID是无效的
throw new CHttpException(404,'此页面不存在');


2. 显示错误
当一个错误被转发给组件CErrorHandler的时候,它会选择合适的视图来显示错误。如果这个错误要显示给最终用户的(比如说一个CHttpException)那么会使用名为errorXXX的视图来显示错误。这个XXX代表着HTTP错误码(比如说400,404,500等)。如果这是个内部错误,应该只能被开发者看到,那么将使用的视图名是exception。在后一种中,将会显示完整的调用栈信息和错误行信息。

信息: 当应用运行在生产模式时,所有的错误,包括内部错误都会使用视图errorXXX。这是因为调用的栈信息和错误行信息可能包含一些敏感信息。这种情况下,开发者应该依靠错误日志来确定错误原因。

CErrorHandler会搜索合适的视图来显示错误信息,搜索的顺序如下:

WebRoot/themes/ThemeName/views/system: 在当前主题视图下的system目录中。

WebRoot/protected/views/system: 在应用的默认视图的system目录中。

yii/framework/views: 在Yii提供的标准视图目录中。

因此,如果你想要自定义错误显示,可以直接在system视图目录中或者主题的system视图目录中创建一个视图文件。每个视图文件都是一个包含许多HTML代码的普通PHP文件。参考框架的view目录下的文件,可以获得更多信息。

3. 使用一个动作来处理错误
Yii也可以使用控制器 动作来处理错误显示。实现的方法是在应用的配置文件中配置一个错误处理器。

return array(
    ......
    'components'=>array(
        'errorHandler'=>array(
            'errorAction'=>'site/error',
        ),
    ),
);
上面的代码中,我们配置了CErrorHandler::errorAction属性,属性值是一个路由site/error。这个路由指向SiteController中的error。当然,你也可以使用其他的路由。

我们可以这样来编写error动作:

public function actionError()
{
    if($error=Yii::app()->errorHandler->error)
        $this->render('error', $error);
}
在这个动作中,首先从CErrorHandler::error中取得详细的错误信息。如果取得的信息非空,就使用CErrorHandler::error返回的信息来渲染error视图。CErrorHandler::error返回的信息是一个数组,结构如下:

code: HTTP 状态码(比如 403, 500);
type: 错误类型(比如 CHttpException, PHP Error);
message: 错误信息;
file: 发生错误的PHP文件名;
line: 错误所在的行;
trace: 错误的调用栈信息;
source: 发生错误的代码的上下文。
提示: 我们检查CErrorHandler::error是否为空的原因是error动作可以被用户访问到,这时候也许并没有什么错误。当我们传递$error数组给视图,它将会被自动释放为独立的变量。所以,在视图中我们可以使用$code,$type来访问这些信息。

4. 消息记录
一个error级别的错误信息会在错误发生时候被记录。如果这个错误是由PHP warning 或 notice引发的,那么这个消息将会被记录在php这个分类中;如果错误信息是由未捕获的异常所引起的,那么分类将是exception.ExceptionClassName(对于CHttpException来说,它的statusCode也将被追加到分类名中)。开发者可以使用这些记录来监测应用执行时候的错误信息

参考资料
http://www.yiiframework.com/doc/guide/1.1/zh_cn/topics.error


如果您觉得本文的内容对您的学习有所帮助,您可以微信:
分享到:
评论

相关推荐

    yii2 开发api接口时优雅的处理全局异常的方法

    Yii2框架中的全局异常处理是通过components配置中的errorHandler组件实现的。开发者可以自定义异常处理器,通过修改配置文件中的errorAction指向一个自定义的异常处理Action。例如,在config/web.php配置文件中,...

    YII Framework教程之异常处理详解

    在本篇教程中,我们将深入探讨YII框架中的异常处理机制,了解它是如何帮助开发者简化错误管理和异常处理工作的。YII框架通过封装和扩展PHP的异常处理能力,提供了一套完善的异常处理机制,让开发者可以更加专注于...

    Yii使用ajax验证显示错误messagebox的解决方法

    需要开发者充分理解Yii的异常处理机制以及Ajax验证的工作流程,方能妥善处理各种情况下的错误信息显示问题。通过自定义错误处理动作,可以实现更加灵活的用户交互体验,使得错误提示既准确又友好。

    ecshop.doc

    - **`includes/cls_error.php`**:错误信息处理类。 - **`includes/lib_time.php`**:时间信息处理类。 - **`includes/lib_base.php`**:基础函数库。 - **`includes/lib_common.php`**:公共业务逻辑功能函数库。 -...

    PHP教程(全套的)

    2. **异常处理**:了解try-catch结构,用以捕获和处理运行时错误。 **模板引擎与框架** 1. **模板引擎**:如Smarty,用于将业务逻辑和视图分离,提高代码可维护性。 2. **PHP框架**:如Laravel、Symfony、Yii等,...

    PHP自学教程 详细教程

    例如,使用try-catch结构捕获并处理异常: ```php try { throw new Exception("错误信息"); } catch (Exception $e) { echo "发生错误: " . $e->getMessage(); } ``` 八、PHP框架与扩展应用 随着PHP的发展,出现...

    PHP基础入门终极教程

    了解如何处理PHP错误和异常是至关重要的。可以通过设置错误报告级别,使用`error_reporting()`和`ini_set()`来控制错误显示。同时,学会使用`var_dump()`和`print_r()`来查看变量信息。 七、PHP面向对象编程 PHP5...

Global site tag (gtag.js) - Google Analytics