PHP Portal » PHP Handbuch » Exceptions erweitern

Werbung

Exceptions erweitern


Eine benutzerdefinierte Exceptionklasse kann durch Ableitung von der eingebauten Exceptionklasse erstellt werden. Die unten angegebenen Methoden und Eigenschaften zeigen, was innerhalb der Kindklasse von der eingebauten Exceptionklasse verfügbar ist.

PHP Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
class Exception { protected $message = 'Unknown exception'; // Exceptionmitteilung protected $code = 0; // Benutzerdefinierte Fehlernummer protected $file; // Quelldateiname der Exception protected $line; // Quelldateizeile der Exception function __construct($message = null, $code = 0); final function getMessage(); // Mitteilung der Exception final function getCode(); // Fehlercode der Exception final function getFile(); // Quelldateiname final function getLine(); // Quelldateizeile final function getTrace(); // Array zum Rückverfolgen final function getTraceAsString(); // Formatierter String der // Rückverfolgung /* Überschreibbar */ function __toString(); // Formatierter String für // Ausgabe }

Wenn eine Klasse die eingebaute Exceptionklasse erweitert und den Konstruktor neu definiert, ist es dringend empfohlen, dass der Konstruktor der Klasse parent::__construct() aufruft, um sicherzustellen, dass alle verfügbaren Daten korrekt zugewiesen wurden. Die __toString()-Methode kann überschrieben werden, um eine maßgeschneiderte Ausgabe anzubieten, wenn das Objekt durch eine Zeichenkette repräsentiert werden soll.

PHP Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/** * Eine maßgeschneiderte Exceptionklasse definieren */ class MyException extends Exception { // Die Exceptionmitteilung neu definieren, damit diese nicht optional ist public function __construct($message, $code = 0) { // etwas Code // sicherstellen, dass alles korrekt zugewiesen wird parent::__construct($message, $code); } // maßgeschneiderte Stringdarstellung des Objektes public function __toString() { return __CLASS__ . ": [{$this->code}]: {$this->message}\n"; } public function customFunction() { echo "Eine eigene Funktion dieses Exceptiontyps\n"; } } /** * Erzeuge eine Klasse, um die Exception zu testen */ 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: // eigene Exception werfen throw new MyException('1 ist ein ungültiger Parameter', 5); break; case self::THROW_DEFAULT: // Vorgabe werfen throw new Exception('2 ist kein zugelassener Parameter', 6); break; default: // Keine Exception, das Objekt wird erzeugt $this->var = $avalue; break; } } } // Beispiel 1 try { $o = new TestException(TestException::THROW_CUSTOM); } catch (MyException $e) { // Wird gefangen echo "Meine Exception gefangen\n", $e; $e->customFunction(); } catch (Exception $e) { // Übersprungen echo "Standardexception gefangen\n", $e; } // Ausführung fortsetzen var_dump($o); echo "\n\n"; // Beispiel 2 try { $o = new TestException(TestException::THROW_DEFAULT); } catch (MyException $e) { // Dieser Typ passt nicht echo "Meine Exception gefangen\n", $e; $e->customFunction(); } catch (Exception $e) { // Wird gefangen echo "Standardexception gefangen\n", $e; } // Ausführung fortsetzen var_dump($o); echo "\n\n"; // Beispiel 3 try { $o = new TestException(TestException::THROW_CUSTOM); } catch (Exception $e) { // Wird gefangen echo "Standardexception gefangen\n", $e; } // Ausführung fortsetzen var_dump($o); echo "\n\n"; // Beispiel 4 try { $o = new TestException(); } catch (Exception $e) { // Übersprungen, keine Exception ausgelöst echo "Standardexception gefangen\n", $e; } // Ausführung fortsetzen var_dump($o); echo "\n\n";