Überprüfen ob Fehlermeldung ausgeben wurde wenn ob_start aktiv ist

Briefkasten

Erfahrenes Mitglied
Hallo,

gibt es eine Möglichkeit zu überprüfen, ob eine Fehlermeldung ausgeben wurde, auch wenn ob_start() aktiviert wurde.

Das Probelm ist ja dieses, dass auch die Fehlermeldungen mit ob_start nicht ausgeben werden.

mfg
 
Kann man den Buffer nicht einfach deaktivieren, wenn eine Fehlermeldung ausgegeben wird ? Oder meinst du PHP-Fehler (E_WARNING, E_NOTICE, ...). Sollte das der Fall sein kannst du dir mal die Funktion set_error_handler() anschauen.
 
Super, Danke du hast mich auf die richtige Spur gebracht.
Im eigenen Fehler Event Hanlder habe ich folgenden Code reingemacht:

PHP:
		$fehler = false;
		switch ($errno)
		{
			case "FATAL":
				echo "<b>FATAL</b> [$errno] $errstr<br />\n";
				echo "  Fatal error in line $errline of file $errfile";
				echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />\n";
				echo "Aborting...<br />\n";
				if($fehler==false)
				{
					if($this->of==null)
					{
						ob_end_clean();
//cache vom ob_start ausgeben
						echo $this->of; 
						$fehler=true;
					}
				}

Allerdings kommt mir das ein wenig unschön vor. Man muss unbedingt überprüfen ob davor auch wirklich nichts ausgeben wurde. Sonst erhält man von der Fehlermeldung eine Fehlermeldung. Desweiteren muss man bei den anderen Fehlermeldungstypen Notice, Error ebenfalls überprüfn ob etwas ausgeben wurde. Sonst wird alles doppelt und dreifach ausgegeben.
 
Wenn kritische Fehler auftreten würde ich das Script sofort stoppen. Wer weiss was genau dann nicht korrekt abgearbeitet werden konnte und welche Lücken sich dadurch auftun. Wenn man noch in der Entwicklung ist, wo normalerweise kein User oder Kunde sein sollte, kann man ruhig alle Fehler hintereinander runterrattern, dann hat der Entwickler einen Überblick, vielleicht hängen auch mehrere Fehler zussammen.

Bei Notice oder E_USER_WARNING usw würde ich dem User das gar nicht mitteilen, sondern in meinen Augen dient es nur dem Programmierer das er hier noch eine Fehlerprüfung einbauen muss oder generell etwas verändern muss, damit sein Script mögliche Usereingaben abfängt (Beispiel: Division by Zero). Diese Fehler erzeugen auch im "Normalbetrieb" des error handlers kein Scriptabbruch und der User kann eh nichts ändern. Daher kann man bei einem selbst definiertem user handler dies unterbinden.

Desweiteren möchte ich hier anmerken das genaue Fehlerursachen nicht dem User vorgeworfen werden sollte. Der Kunde oder Benutzer sollte in meinen Augen nicht wissen, wie eine Datei heisst wo der Fehler auftritt und was der Fehlergrund ist. Für den, ich sag jetzt einfachmal DAU User sind das nur kryptische Buchstaben. Böswillige User haben Anhaltspunkte wie ein Script aufgebaut sein kann und Lücken sein könnten.
Von daher mein Rat, das wenn ein kritischer Fehler auftritt, der User nur eine Meldung kriegen sollte, das es ein Fehler aufgetreten ist, eventuell falls die Scriptlogik es noch zulässt einen simplen und verständlichen Grund angeben und sich entschuldigen. Im Anschluss muss der Webmaster per logfile oder per Mail (uhh, bei vielen fehlern) informiert werden. Auch darüber sollte der User informiert werden, daß der Fehler an den Webmaster gemeldet wurde und der sich ASAP darum kümmert.

Vielleicht hilft dir das in deinen Entscheidungen.
 
Zurück