This site is mobile accessible. Press the "Tap Here" button to use a different font-size.
Smartphone icons created by Freepik - Flaticon
<?php function divide($dividend, $divisor) { if($divisor == 0) { throw new Exception("Division by zero"); } return $dividend / $divisor; } echo divide(5, 0); ?>
The result will look something like this:
Fatal error: Uncaught Exception: Division by zero in C:\webfolder\test.php:4
Stack trace: #0 C:\webfolder\test.php(9):
divide(5, 0) #1 {main} thrown in C:\webfolder\test.php on line 4
[Wed Sep 18 16:18:22.974257 2024] [php7:error] [pid 5468] [client ::1:55908]
PHP Fatal error: Uncaught Exception: Division by zero in
/srv/www/htdocs/W3School-WebDevelopment/php/PHPExceptions.php:41\n
Stack trace:\n#0 /srv/www/htdocs/W3School-WebDevelopment/php/PHPExceptions.php(46): divide()\n#1
{main}\n thrown in /srv/www/htdocs/W3School-WebDevelopment/php/PHPExceptions.php on line 41,
referer: http://localhost/W3School-WebDevelopment/php/6-13PHPExceptions.php
To avoid the error from the example above, we can use the
statement to catch exceptions and continue the process.try {
code that can throw exceptions
} catch(Exception $e) {
code that runs when an exception is caught
}
Show a message when an exception is thrown:
<?php function divide($dividend, $divisor) { if($divisor == 0) { throw new Exception("Division by zero"); } return $dividend / $divisor; } try { echo divide(5, 0); } catch(Exception $e) { echo "Unable to divide."; } ?>
The catch block indicates what type of exception should be caught and the name of the variable which can be used to access the exception. In the example above, the type of exception is
and the variable name is $e.The
statement can be used to catch exceptions. Code in the block will always run regardless of whether an exception was caught. If is present, the block is optional.try {
code that can throw exceptions
} catch(Exception $e) {
code that runs when an exception is caught
} finally {
code that always runs regardless of whether an exception was caught
}
Show a message when an exception is thrown and then indicate that the process has ended:
<?php function divide($dividend, $divisor) { if($divisor == 0) { throw new Exception("Division by zero"); } return $dividend / $divisor; } try { echo divide(5, 0); } catch(Exception $e) { echo "Unable to divide. "; } finally { echo "Process complete."; } ?>
Output a string even if an exception was not caught:
<?php function divide($dividend, $divisor) { if($divisor == 0) { throw new Exception("Division by zero"); } return $dividend / $divisor; } try { echo divide(5, 0); } finally { echo "Process complete."; } ?>
The Exception Object contains information about the error or unexpected behaviour that the function encountered.
new Exception(message, code, previous)
Parameter | Description |
---|---|
message | Optional. A string describing why the exception was thrown |
code | Optional. An integer that can be used used to easily distinguish this exception from others of the same type |
previous | Optional. If this exception was thrown in a catch block of another exception, it is recommended to pass that exception into this parameter |
When catching an exception, the following table shows some of the methods that can be used to get information about the exception:
Method | Description |
---|---|
getMessage() | Returns a string describing why the exception was thrown |
getPrevious() | If this exception was triggered by another one, this method returns the previous exception. If not, then it returns null |
getCode() | Returns the exception code |
getFile() | Returns the full path of the file in which the exception was thrown |
getLine() | Returns the line number of the line of code which threw the exception |
Output information about an exception that was thrown:
<?php function divide($dividend, $divisor) { if($divisor == 0) { throw new Exception("Division by zero", 1); } return $dividend / $divisor; } try { echo divide(5, 0); } catch(Exception $ex) { $code = $ex->getCode(); $message = $ex->getMessage(); $file = $ex->getFile(); $line = $ex->getLine(); echo "Exception thrown in $file on line $line: [Code $code] $message"; } ?>
Eventually the navigation links, above, will be replaced by these (previous) and (next) buttons below.
Animated PHP icons used in the buttons provided by ICONS8.COM. Smartphone icons created by Freepik - Flaticon
Module 6 quiz