error.md 1.73 KB
Newer Older
Alexander Makarov committed
1 2 3
Error Handling
==============

4 5 6 7
Error handling in Yii is different from plain PHP. First of all, all non-fatal errors are converted to exceptions so
you can use `try`-`catch` to work with these. Second, even fatal errors are rendered in a nice way. In debug mode that
means you have a trace and a piece of code where it happened so it takes less time to analyze and fix it.

8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
Using controller action to render errors
----------------------------------------

Default Yii error page is great for development mode and is OK for production if `YII_DEBUG` is turned off but you may
have an idea how to make it more suitable for your project. An easiest way to customize it is to use controller action
for error rendering. In order to do so you need to configure `errorHandler` component via application config:

```php
return [
    // ...
    'components' => [
        // ...
        'errorHandler' => [
            'errorAction' => 'site/error',
    ],
```

25
After it is done in case of error, Yii will launch `SiteController::actionError()`:
26 27 28 29

```php
public function actionError()
{
30 31 32
    if (\Yii::$app->exception !== null) {
        return $this->render('error', ['exception' => \Yii::$app->exception]);
    }
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
}
```

Since most of the time you need to adjust look and feel only, Yii provides `ErrorAction` class that can be used in
controller instead of implementing action yourself:

```php
public function actions()
{
    return [
        'error' => [
            'class' => 'yii\web\ErrorAction',
        ],
    ];
}
```

After defining `actions` in `SiteController` as shown above you can create `views/site/error.php`. In the view there
51
are three variables available:
52 53 54 55 56

- `$name`: the error name
- `$message`: the error message
- `$exception`: the exception being handled