


Yii Framework Official Guide Series 46 - Special Topic: Error Handling
Yii provides a complete error handling mechanism based on PHP5 exception handling. When an application starts running and handles user requests, the handleError method is registered to handle PHP warnings and notices information; the handleException method is also registered to handle uncaught PHP exceptions. Therefore, if a PHP warning/notice or an uncaught PHP exception occurs while the application is running, the error handler will take over control and run the necessary handling mechanisms.
Tips: The error handler is registered in the constructor method of the application, using the PHP functions set_exception_handler and set_error_handler. If you don't want Yii to handle errors and exceptions, you can define
YII_ENABLE_ERROR_HANDLER
andYII_ENABLE_EXCEPTION_HANDLER
as false in the entry file.
By default, in When the onError event (or onException event) is triggered, the errorHandler (or exceptionHandler) will be triggered. If the error or exception is not handled by any event, then you need to run the errorHandler component to handle it.
1. Raising exceptions
Raising exceptions in Yii is no different from ordinary PHP files. You can use the following code to throw an exception:
throw new ExceptionClass('错误信息');
Yii defines two exception classes: CException and CHttpException . The former is a general exception class, while the latter is used to display exception information to end users. At the same time, the latter has a statusCode attribute to represent the HTTP status code. The type of exception determines the display effect, which will be discussed in detail below.
Tips: If you want to tell the user that a certain operation is wrong, throwing a CHttpException is the easiest way. For example, if the user provides an invalid ID value in the URL, we can display a 404 error:
// 如果提交的ID是无效的 throw new CHttpException(404,'此页面不存在');
2. Display errors
When an error is forwarded to the component CErrorHandler, it will select the appropriate view to display the error. If the error is to be displayed to the end user (for example, a CHttpException) then a view named errorXXX
will be used to display the error. This XXX
represents the HTTP error code (such as 400, 404, 500, etc.). If this is an internal error that should only be visible to developers, the view name that will be used is exception
. In the latter case, the complete call stack information and error line information will be displayed.
Information: When the application is running in production mode, all errors, including internal errors, will use view
errorXXX
. This is because the call stack information and error line information may contain some sensitive information. In this case, developers should rely on error logs to determine the cause of the error.
CErrorHandler will search for the appropriate view to display the error message. The search order is as follows:
##WebRoot/themes/ThemeName/views/system
: In the
systemdirectory under the current theme view.
WebRoot/protected/views/system
: In the
systemdirectory of the application's default view.
yii/framework/views
: In the standard view directory provided by Yii.
system view directory or the theme's
system view directory A view file. Each view file is a regular PHP file containing a lot of HTML code. Refer to the files in the
view directory of the framework for more information.
return array( ...... 'components'=>array( 'errorHandler'=>array( 'errorAction'=>'site/error', ), ), );
site/error. This route points to
error in
SiteController. Of course, you can also use other routes.
error action like this:
public function actionError() { if($error=Yii::app()->errorHandler->error) $this->render('error', $error); }
error view. The information returned by CErrorHandler::error is an array with the following structure:
-
code
: HTTP status code (such as 403, 500);
type
: Error type (such as CHttpException,
PHP Error);
message
: Error message;
file
: The name of the PHP file where the error occurred;
line
: The line where the error is located;
trace
: Error call stack information;
source
: The context of the code where the error occurred.
Tip: The reason why we check whether CErrorHandler::error is empty is that the
error
action can be accessed by the user. At this time, it may not be possible. Nothing wrong. When we pass the$error
array to the view, it will be automatically released as an independent variable. Therefore, in the view we can use$code
,$type
to access this information.
4. Message recording
An error
level error message will be recorded when an error occurs. If the error is caused by a PHP warning or notice, the message will be logged in the php
category; if the error message is caused by an uncaught exception, the category will be exception.ExceptionClassName
(For CHttpException, its statusCode will also be appended to the class name). Developers can use these records to monitor error messages during application execution
The above is Yii Framework Official Guide Series 46 - Special Topic: Error Handling. For more related content, please pay attention to the PHP Chinese website (www.php .cn)!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Use middleware to improve error handling in Go functions: Introducing the concept of middleware, which can intercept function calls and execute specific logic. Create error handling middleware that wraps error handling logic in a custom function. Use middleware to wrap handler functions so that error handling logic is performed before the function is called. Returns the appropriate error code based on the error type, улучшениеобработкиошибоквфункциях Goспомощьюпромежуточногопрограммногообеспечения.Оно позволяетнамсосредоточитьсянаобработкеошибо

In C++, exception handling handles errors gracefully through try-catch blocks. Common exception types include runtime errors, logic errors, and out-of-bounds errors. Take file opening error handling as an example. When the program fails to open a file, it will throw an exception and print the error message and return the error code through the catch block, thereby handling the error without terminating the program. Exception handling provides advantages such as centralization of error handling, error propagation, and code robustness.

The best error handling tools and libraries in PHP include: Built-in methods: set_error_handler() and error_get_last() Third-party toolkits: Whoops (debugging and error formatting) Third-party services: Sentry (error reporting and monitoring) Third-party libraries: PHP-error-handler (custom error logging and stack traces) and Monolog (error logging handler)

Error handling and logging in C++ class design include: Exception handling: catching and handling exceptions, using custom exception classes to provide specific error information. Error code: Use an integer or enumeration to represent the error condition and return it in the return value. Assertion: Verify pre- and post-conditions, and throw an exception if they are not met. C++ library logging: basic logging using std::cerr and std::clog. External logging libraries: Integrate third-party libraries for advanced features such as level filtering and log file rotation. Custom log class: Create your own log class, abstract the underlying mechanism, and provide a common interface to record different levels of information.

In Go functions, asynchronous error handling uses error channels to asynchronously pass errors from goroutines. The specific steps are as follows: Create an error channel. Start a goroutine to perform operations and send errors asynchronously. Use a select statement to receive errors from the channel. Handle errors asynchronously, such as printing or logging error messages. This approach improves the performance and scalability of concurrent code because error handling does not block the calling thread and execution can be canceled.

In Go function unit testing, there are two main strategies for error handling: 1. Represent the error as a specific value of the error type, which is used to assert the expected value; 2. Use channels to pass errors to the test function, which is suitable for testing concurrent code. In a practical case, the error value strategy is used to ensure that the function returns 0 for negative input.

In Golang, error wrappers allow you to create new errors by appending contextual information to the original error. This can be used to unify the types of errors thrown by different libraries or components, simplifying debugging and error handling. The steps are as follows: Use the errors.Wrap function to wrap the original errors into new errors. The new error contains contextual information from the original error. Use fmt.Printf to output wrapped errors, providing more context and actionability. When handling different types of errors, use the errors.Wrap function to unify the error types.

Best practices for error handling in Go include: using the error type, always returning an error, checking for errors, using multi-value returns, using sentinel errors, and using error wrappers. Practical example: In the HTTP request handler, if ReadDataFromDatabase returns an error, return a 500 error response.
