search
HomeBackend DevelopmentPHP TutorialPHP5 exception handling, error throwing and callback functions, etc.

  1. error_reporting(E_ALL&~E_NOTICE); // In addition to E_NOTICE, other exceptions will be triggered (the binary operation result of E_ALL&~E_NOTICE is: the value of the corresponding bit of E_NOTICE is set to 0) try-catch cannot be automatically loaded in the class Valid within function __autoload().
  2. try-catch cannot be used to catch exceptions and errors, such as errors triggered by trigger_error(). Exceptions and errors are different.
  3. try{
  4. // you codes that maybe cause an error
  5. }catch(Exception $err){ // This error object needs to declare the type, Exception is the system default exception handling class
  6. echo $err->getMessage();
  7. }
Copy code

//thrown can throw an exception, such as: thrown new Exception('an error'); one example:

  1. try {
  2. if ( empty( $var1 ) ) throw new NotEmptyException();
  3. if ( empty( $var2 ) ) throw new NotEmptyException();
  4. if ( ! preg_match() ) throw new InvalidInputException( );
  5. $model->write();
  6. $template->render( 'success' );
  7. } catch ( NotEmptyException $e ) {
  8. $template->render( 'error_empty' );
  9. } catch (InvalidInputException $e) {
  10. $template->render( 'error_preg' );
  11. }
Copy code

Exception class structure: most of the methods are prohibited from being overridden (final)

  1. Exception {
  2. /* attribute*/
  3. protected string $message ;
  4. protected int $code ;
  5. protected string $file ;
  6. protected int $line ;
  7. /* method*/
  8. public __construct ([ string $message = "" [, int $code = 0 [, Exception $previous = null]]] )
  9. final public string getMessage ( void ) //The message thrown by the exception
  10. final public Exception getPrevious ( void ) //Previous Exception
  11. final public int getCode (void) //Exception code, this is user-defined
  12. final public string getFile (void) //The file path where the exception occurred
  13. final public int getLine (void) //The line where the exception occurred
  14. final public array getTrace (void) //Exception tracking information (array)
  15. final public string getTraceAsString (void) //Exception tracking information (string)
  16. public string __toString (void) //Trying to treat the exception object directly as a string The return value of calling the sub-function when used
  17. final private void __clone (void) //Called when cloning the exception object
  18. }
Copy code

Extended exception class try-catch can have multiple catch clauses. Starting from the first catch clause, if the exception variable type in the clause matches the exception type thrown by the throw statement, the clause will be executed and no other catch clauses will be executed. clause, otherwise continue to try the next catch clause. Since Exception is the base class of all exception classes, the exceptions thrown will match it. If you use different processing methods according to different exception types, you should use Exception type The catch clause goes last. Exception is the base class of all exceptions. You can extend the exception class according to actual needs.

  1. calss MyException extends Exception{
  2. public errType = 'default';
  3. public function __construct($errType=''){
  4. $this->errType = $errType;
  5. }
  6. }
  7. thrown new MyException (); //Throw an exception
  8. try{
  9. // you codes that maybe cause an error
  10. }catch(MyException $err){ // This error object needs to declare the type
  11. echo $err->errType();
  12. }catch(ErrorException $err){ //ErrorException is an exception class added in PHP 5, inherited from Exception
  13. echo 'error !';
  14. }catch(Exception $err){
  15. redirect('/error.php');
  16. }
Copy code

You may determine the type of exception in the catch clause, or decide whether to handle the exception based on code and other information. If the code you unload the catch clause cannot properly handle the caught exception, you can continue to throw it within the catch clause. Exception occurred.

3. Exception callback function set_exception_handler(callback functionName) //This function will be called when an exception of Exception or its subclass occurs function exceptionHandlerFun($errObj){ // Exception exception callback function has only one parameter, which is the thrown exception object. //....... }

Exception exception callback function cannot eliminate the exception by returning true like set_error_handler's callback function. Even if the callback function handles the exception, subsequent code will not continue to be executed, so if you want to continue executing subsequent code, try-catch must be used . But there is an exception: the script end callback function can be executed, and the callback function can be executed even if the thrown exception is not handled. register_shutdown_function(callback functionName[,argument1,argument2,...]); For example:

  1. function shutdownfunction(){

  2. echo 'script is end';
  3. }
  4. register_shutdown_function("shutdownfunction");

Copy code

Because shutdownfunction() is executed at the end of the script, this callback function can call a function anywhere in the script, even if the function is defined after the error is thrown (the function definition is in the script Completed during compilation).

4. trigger_error(string errorMsg[,int user_error_type]) This function is used to actively trigger an error: user_error_type can only be the value of E_ALL, E_USER_ERROR, E_USER_WARNING, E_USER_NOTICE or a combination thereof. set_error_handler(callbeck functionName[,user_error_type]); //Set a callback function for trigger_error() to handle errors, including errors thrown by the system and errors triggered by the user using the trigger_error() function.

Optional parameter user_error_type: If this parameter is set, the callback function can be triggered only when the error type thrown by trigger_error matches the definition range of user_error_type. This value is set similarly to the error_reporting() function.

First parameter (callbeck functionName): A function name. The function can have 5 parameters, of which the first 2 are required, in order: The user_error_type that trigger_error throws, the errorMsg that trigger_error throws, the absolute path of the file that throws the error, the line number that throws the error, and the context when the error is thrown (an array that contains everything in the scope where trigger_error() is located. variables, functions, classes and other data) Return value of the callback function: If false is returned, the system error handling mechanism will continue to throw the error, and return true or no return value to eliminate the error. Errors triggered by trigger_error() will not be caught by try-catch exception catching statements.



Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Working with Flash Session Data in LaravelWorking with Flash Session Data in LaravelMar 12, 2025 pm 05:08 PM

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

cURL in PHP: How to Use the PHP cURL Extension in REST APIscURL in PHP: How to Use the PHP cURL Extension in REST APIsMar 14, 2025 am 11:42 AM

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Build a React App With a Laravel Back End: Part 2, ReactBuild a React App With a Laravel Back End: Part 2, ReactMar 04, 2025 am 09:33 AM

This is the second and final part of the series on building a React application with a Laravel back-end. In the first part of the series, we created a RESTful API using Laravel for a basic product-listing application. In this tutorial, we will be dev

Simplified HTTP Response Mocking in Laravel TestsSimplified HTTP Response Mocking in Laravel TestsMar 12, 2025 pm 05:09 PM

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

12 Best PHP Chat Scripts on CodeCanyon12 Best PHP Chat Scripts on CodeCanyonMar 13, 2025 pm 12:08 PM

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Notifications in LaravelNotifications in LaravelMar 04, 2025 am 09:22 AM

In this article, we're going to explore the notification system in the Laravel web framework. The notification system in Laravel allows you to send notifications to users over different channels. Today, we'll discuss how you can send notifications ov

Explain the concept of late static binding in PHP.Explain the concept of late static binding in PHP.Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

PHP Logging: Best Practices for PHP Log AnalysisPHP Logging: Best Practices for PHP Log AnalysisMar 10, 2025 pm 02:32 PM

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment