It's important to note that subclasses of the Exception class will be caught by the default Exception handler
<?php
/**
* NewException
* Extends the Exception class so that the $message parameter is now mendatory.
*
*/
class NewException extends Exception {
//$message is now not optional, just for the extension.
public function __construct($message, $code = 0, Exception $previous = null) {
parent::__construct($message, $code, $previous);
}
}
/**
* TestException
* Tests and throws Exceptions.
*/
class TestException {
const NONE = 0;
const NORMAL = 1;
const CUSTOM = 2;
public function __construct($type = self::NONE) {
switch ($type) {
case 1:
throw new Exception('Normal Exception');
break;
case 2:
throw new NewException('Custom Exception');
break;
default:
return 0; //No exception is thrown.
}
}
}
try {
$t = new TestException(TestException::CUSTOM);
}
catch (Exception $e) {
print_r($e); //Exception Caught
}
?>
Note that if an Exception is caught once, it won't be caught again (even for a more specific handler).
예외 확장하기
내장 Exception 클래스를 확장하여 사용자 정의 예외 클래스를 정의할 수 있습니다. 멤버와 프로퍼티는 아래에 있습니다. 내장 Exception 클래스에서 상속받은 자식 클래스에서 어떤 것에 접근할 수 있는지 확인하십시오.
Example #1 내장 Exception 클래스
<?php
class Exception
{
protected $message = 'Unknown exception'; // 예외 메세지
protected $code = 0; // 사용자 정의 예외 코드
protected $file; // 예외 소스 파일명
protected $line; // 예외 소스 줄
function __construct($message = null, $code = 0);
final function getMessage(); // 예외 메세지
final function getCode(); // 예외 코드
final function getFile(); // 소스 파일명
final function getLine(); // 소스 줄
final function getTrace(); // backtrace() 배열
final function getTraceAsString(); // 추적의 형식화된 문자열
/* Overrideable */
function __toString(); // 출력용 형식화된 문자열
}
?>
내장 Exception 클래스를 확장해서 생성자를 재정의할 경우에는, parent::__construct()를 호출하여 모든 사용가능한 데이터가 적합하게 할당될 수 있도록 하길 권합니다. __toString() 메쏘드를 덮어써서, 객체가 문자열로 표현될 때 사용자 출력을 제공할 수 있습니다.
Example #2 Exception 클래스 확장하기
<?php
/**
* 사용자 예외 클래스 정의
*/
class MyException extends Exception
{
// 예외를 재정의해서 메세지가 필수가 됩니다
public function __construct($message, $code = 0) {
// some code
// 모든 것이 제대로 할당되도록 합니다
parent::__construct($message, $code);
}
// 객체의 사용자 문자열 표현
public function __toString() {
return __CLASS__ . ": [{$this->code}]: {$this->message}\n";
}
public function customFunction() {
echo "A Custom function for this type of exception\n";
}
}
/**
* 예외를 시험하는 클래스 생성
*/
class TestException
{
public $var;
const THROW_NONE = 0;
const THROW_CUSTOM = 1;
const THROW_DEFAULT = 2;
function __construct($avalue = self::THROW_NONE) {
switch ($avalue) {
case self::THROW_CUSTOM:
// 사용자 예외 던지기
throw new MyException('1 is an invalid parameter', 5);
break;
case self::THROW_DEFAULT:
// 기본 예외 던지기
throw new Exception('2 is not allowed as a parameter', 6);
break;
default:
// 예외 없음, 객체 생성.
$this->var = $avalue;
break;
}
}
}
// 예제 1
try {
$o = new TestException(TestException::THROW_CUSTOM);
} catch (MyException $e) { // 잡아집니다
echo "Caught my exception\n", $e;
$e->customFunction();
} catch (Exception $e) { // 무시
echo "Caught Default Exception\n", $e;
}
// 계속 실행
var_dump($o);
echo "\n\n";
// 예제 2
try {
$o = new TestException(TestException::THROW_DEFAULT);
} catch (MyException $e) { // 형식에 맞지 않음
echo "Caught my exception\n", $e;
$e->customFunction();
} catch (Exception $e) { // 잡아집니다
echo "Caught Default Exception\n", $e;
}
// 계속 실행
var_dump($o);
echo "\n\n";
// 예제 3
try {
$o = new TestException(TestException::THROW_CUSTOM);
} catch (Exception $e) { // 잡아집니다
echo "Default Exception caught\n", $e;
}
// 계속 실행
var_dump($o);
echo "\n\n";
// 예제 4
try {
$o = new TestException();
} catch (Exception $e) { // 무시, 예외 없음
echo "Default Exception caught\n", $e;
}
// 계속 실행
var_dump($o);
echo "\n\n";
?>
Dor
15-Oct-2011 02:30
joechrz at gmail dot com
18-Feb-2010 03:18
It's important to note some unexpected behavior when overriding the __toString method of an Exception. The default PHP exception handler will truncate the result of the __toString method to the number of bytes specified by log_errors_max_len in php.ini.
To get around this problem, you need to either change the value of log_errors_max_len:
<?php
// recommended: disable error logging
// so the log files don't become bloated from huge
// exception strings
ini_set('log_errors','off');
// log_errors_max_len = infinite length
ini_set("log_errors_max_len",0);
?>
or specify a custom exception handler:
<?php
function long_exception_handler($exception) {
// for compatibility, call __toString
echo $exception->__toString();
}
set_exception_handler('long_exception_handler');
?>
iamhiddensomewhere at gmail dot com
31-Dec-2009 03:17
As previously noted exception linking was recently added (and what a god-send it is, it certainly makes layer abstraction (and, by association, exception tracking) easier).
Since <5.3 was lacking this useful feature I took some initiative and creating a custom exception class that all of my exceptions inherit from:
<?php
class SystemException extends Exception
{
private $previous;
public function __construct($message, $code = 0, Exception $previous = null)
{
parent::__construct($message, $code);
if (!is_null($previous))
{
$this -> previous = $previous;
}
}
public function getPrevious()
{
return $this -> previous;
}
}
?>
Hope you find it useful.
sapphirepaw.org
24-Nov-2009 07:37
Support for exception linking was added in PHP 5.3.0. The getPrevious() method and the $previous argument to the constructor are not available on any built-in exceptions in older versions of PHP.
paragdiwan at gmail dot com
17-Jan-2009 01:32
I have written similar simple custom exception class. Helpful for newbie.
<?php
/*
This is written for overriding the exceptions.
custom exception class
*/
error_reporting(E_ALL-E_NOTICE);
class myCustomException extends Exception
{
public function __construct($message, $code=0)
{
parent::__construct($message,$code);
}
public function __toString()
{
return "<b style='color:red'>".$this->message."</b>";
}
}
class testException
{
public function __construct($x)
{
$this->x=$x;
}
function see()
{
if($this->x==9 )
{
throw new myCustomException("i didnt like it");
}
}
}
$obj = new testException(9);
try{
$obj->see();
}
catch(myCustomException $e)
{
echo $e;
}
?>
