Heim Backend-Entwicklung PHP-Tutorial 2.PHP怎么记录异常和发送异常

2.PHP怎么记录异常和发送异常

Jun 13, 2016 pm 12:22 PM
error errors log message set

2.PHP如何记录错误和发送错误

1. 将错误记录到指定的文件中,配置过程如下
* 1). log_errors=on
* 2). error_log=/tmp/php_error.log
1.使用error_log()函数记录错误日志
error_log(‘要记录的错误信息!’);

<code class="language-php hljs ">header(<span class="hljs-string">'content-type:text/html; charset=utf-8'</span>);<span class="hljs-comment">//开启所有的错误报告</span>error_reporting(-<span class="hljs-number">1</span>);<span class="hljs-comment">//设置时区</span>ini_set(<span class="hljs-string">'date.timezone'</span>, <span class="hljs-string">'PRC'</span>);<span class="hljs-comment">//禁用页面显示错误</span>ini_set(<span class="hljs-string">'display_errors'</span>, <span class="hljs-number">0</span>);<span class="hljs-comment">//开启日志记录功能</span>ini_set(<span class="hljs-string">'log_errors'</span>, <span class="hljs-number">1</span>);<span class="hljs-comment">//设置错误日志保存的位置</span>ini_set(<span class="hljs-string">'error_log'</span>, <span class="hljs-string">'/tmp/custom_error.log'</span>);<span class="hljs-comment">//忽略重复的错误</span>ini_set(<span class="hljs-string">'ignore_repeated_errors'</span>, <span class="hljs-string">'on'</span>);<span class="hljs-comment">//忽略重复的错误来源</span>ini_set(<span class="hljs-string">'ignore_repeated_source'</span>, <span class="hljs-string">'on'</span>);error_log(<span class="hljs-string">'我要把你记录到我的自定义错误日志中'</span>.date(<span class="hljs-string">'Y-m-d H:i:s'</span>, time()));trigger_error(<span class="hljs-string">'trigger_error-----我要把你记录到我的系统错误日志中'</span>.date(<span class="hljs-string">'Y-m-d H:i:s'</span>, time()), E_USER_NOTICE);settype(<span class="hljs-variable">$var</span>, <span class="hljs-string">'king'</span>);</code>
Nach dem Login kopieren

2.将错误记录到系统日志中
* 1.ini_set('error_log', 'syslog');常用

<code class="language-php hljs ">方法一<span class="hljs-comment">//开启所有的错误报告</span>error_reporting(-<span class="hljs-number">1</span>);<span class="hljs-comment">//禁用页面显示错误</span>ini_set(<span class="hljs-string">'display_errors'</span>, <span class="hljs-number">0</span>);<span class="hljs-comment">//开启日志记录功能</span>ini_set(<span class="hljs-string">'log_errors'</span>, <span class="hljs-number">1</span>);<span class="hljs-comment">//设置错误日志保存的位置------(系统日志)</span>ini_set(<span class="hljs-string">'error_log'</span>, <span class="hljs-string">'syslog'</span>);<span class="hljs-comment">//忽略重复的错误</span>ini_set(<span class="hljs-string">'ignore_repeated_errors'</span>, <span class="hljs-string">'on'</span>);<span class="hljs-comment">//忽略重复的错误来源</span>ini_set(<span class="hljs-string">'ignore_repeated_source'</span>, <span class="hljs-string">'on'</span>);<span class="hljs-comment">// error_log('error_log-----我要把你记录到我的系统错误日志中'.date('Y-m-d H:i:s', time()));</span>trigger_error(<span class="hljs-string">'trigger_error-----我要把你记录到我的系统错误日志中'</span>.date(<span class="hljs-string">'Y-m-d H:i:s'</span>, time()), E_USER_NOTICE);<span class="hljs-comment">// settype($var, 'king');</span>方法二<span class="hljs-comment">//====================出于安全问题不用===========================</span><span class="hljs-comment">//打开到系统日志的链接</span>openlog(<span class="hljs-string">'PHP5.6.0'</span>, LOG_PID, LOG_SYSLOG);syslog(LOG_ERR, <span class="hljs-string">'this is a test syslog'</span>.date(<span class="hljs-string">'Y-m-d H:i:s'</span>, time()));closelog();</code>
Nach dem Login kopieren

2.将错误日志通过邮件发送
* 1.error_log('msg', 1, mail_addr); 第二个参数设置为1
** bool error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] )

<code class=" hljs cmake"><span class="hljs-keyword">message</span>应该被记录的错误信息。message_type设置错误应该发送到何处。可能的信息类型有以下几个:error_log() 日志类型<span class="hljs-number">0</span>   <span class="hljs-keyword">message</span> 发送到 PHP 的系统日志,使用 操作系统的日志机制或者一个文件,取决于 error_log 指令设置了什么。 这是个默认的选项。<span class="hljs-number">1</span>   <span class="hljs-keyword">message</span> 发送到参数 destination 设置的邮件地址。 第四个参数 extra_headers 只有在这个类型里才会被用到。<span class="hljs-number">2</span>   不再是一个选项。<span class="hljs-number">3</span>   <span class="hljs-keyword">message</span> 被发送到位置为 destination 的文件里。 字符 <span class="hljs-keyword">message</span> 不会默认被当做新的一行。<span class="hljs-number">4</span>   <span class="hljs-keyword">message</span> 直接发送到 SAPI 的日志处理程序中。destination目标。它的含义描述于以上,由 message_type 参数所决定。extra_headers额外的头。当 message_type 设置为 <span class="hljs-number">1</span> 的时候使用。 该信息类型使用了 mail() 的同一个内置函数。</code>
Nach dem Login kopieren
<code class="language-php hljs "><span class="hljs-comment">//开启所有的错误报告</span>error_reporting(-<span class="hljs-number">1</span>);<span class="hljs-comment">//禁用页面显示错误</span>ini_set(<span class="hljs-string">'display_errors'</span>, <span class="hljs-number">0</span>);<span class="hljs-comment">//开启日志记录功能</span>ini_set(<span class="hljs-string">'log_errors'</span>, <span class="hljs-number">1</span>);<span class="hljs-comment">//忽略重复的错误</span>ini_set(<span class="hljs-string">'ignore_repeated_errors'</span>, <span class="hljs-string">'on'</span>);<span class="hljs-comment">//忽略重复的错误来源</span>ini_set(<span class="hljs-string">'ignore_repeated_source'</span>, <span class="hljs-string">'on'</span>);<span class="hljs-comment">//设置第二个参数为1将,使用邮件发送错误日志信息</span>error_log(<span class="hljs-string">'error_log-----我要把你记录到我的系统错误日志中'</span>.date(<span class="hljs-string">'Y-m-d H:i:s'</span>, time()), <span class="hljs-number">1</span>, <span class="hljs-string">[email&#160;protected]'</span>);</code>
Nach dem Login kopieren

版权声明:本文为博主原创文章,未经博主允许不得转载。

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Lösung für PHP Schwerwiegender Fehler: Aufruf der undefinierten Methode PDO::prepare() in Lösung für PHP Schwerwiegender Fehler: Aufruf der undefinierten Methode PDO::prepare() in Jun 22, 2023 pm 06:40 PM

PHP ist eine beliebte Webentwicklungssprache, die schon seit langem verwendet wird. Die in PHP integrierte PDO-Klasse (PHP Data Object) ist für uns eine gängige Möglichkeit, bei der Entwicklung von Webanwendungen mit der Datenbank zu interagieren. Ein Problem, auf das einige PHP-Entwickler jedoch häufig stoßen, besteht darin, dass sie bei Verwendung der PDO-Klasse zur Interaktion mit der Datenbank eine Fehlermeldung wie diese erhalten: PHPFatalerror:CalltoundefinedmethodPDO::prep

Was soll ich tun, wenn bei der Verwendung von Axios in einer Vue-Anwendung „Uncaught (in Promise) Error: Request failed with status code 500' auftritt? Was soll ich tun, wenn bei der Verwendung von Axios in einer Vue-Anwendung „Uncaught (in Promise) Error: Request failed with status code 500' auftritt? Jun 24, 2023 pm 05:33 PM

Axios wird häufig in Vue-Anwendungen verwendet. Axios ist ein Promise-basierter HTTP-Client, der in Browsern und Node.js verwendet werden kann. Während des Entwicklungsprozesses erscheint manchmal die Fehlermeldung „Uncaught(inpromise)Error: Requestfailedwithstatuscode500“. Für Entwickler kann diese Fehlermeldung schwer zu verstehen und zu lösen sein. In diesem Artikel wird dies untersucht

Lösen Sie das Problem „Fehler: Unvollständiger Typ ist nicht zulässig' im C++-Code Lösen Sie das Problem „Fehler: Unvollständiger Typ ist nicht zulässig' im C++-Code Aug 26, 2023 pm 08:54 PM

Lösen Sie das „error:incompletetypeisnotallowed“-Problem im C++-Code. Während des C++-Programmierungsprozesses treten manchmal einige Kompilierungsfehler auf. Dieser Fehler wird normalerweise durch die Arbeit mit einem unvollständigen Typ verursacht. In diesem Artikel wird die Ursache dieses Fehlers erläutert und verschiedene Lösungen bereitgestellt. Zunächst einmal: Ich

0271: Was soll ich tun, wenn der Computer aufgrund eines Echtzeituhrfehlers nicht eingeschaltet werden kann? 0271: Was soll ich tun, wenn der Computer aufgrund eines Echtzeituhrfehlers nicht eingeschaltet werden kann? Mar 13, 2023 am 11:30 AM

Lösung für „0271: Echtzeituhrfehler“, der nicht gestartet werden kann: 1. Drücken Sie F1 und verschieben Sie in der angezeigten Benutzeroberfläche die Optionsleiste zum dritten Element „Datum/Uhrzeit“. 2. Ändern Sie die Systemzeit manuell auf die aktuelle Uhrzeit einmal; 3. Drücken Sie F10 und wählen Sie im Popup-Dialogfeld „Ja“ aus. 4. Öffnen Sie das Notebook erneut, um es normal zu starten.

Lösen Sie das Problem „Fehler: erwarteter Initialisierer vor ‚Datentyp'' im C++-Code Lösen Sie das Problem „Fehler: erwarteter Initialisierer vor ‚Datentyp'' im C++-Code Aug 25, 2023 pm 01:24 PM

Lösen Sie das „error:expectedinitializerbefore'datatype‘“-Problem in C++-Code. Beim Schreiben von Code treten manchmal Kompilierungsfehler auf. Einer der häufigsten Fehler ist „error:expectedinitializerbefore‘datatype‘“. Dieser Fehler tritt normalerweise in einer Variablendeklaration oder Funktionsdefinition auf und kann dazu führen, dass das Programm nicht korrekt kompiliert werden kann oder

Ausführliche Erläuterung der Funktion „Tag festlegen' in den dynamischen SQL-Tags von MyBatis Ausführliche Erläuterung der Funktion „Tag festlegen' in den dynamischen SQL-Tags von MyBatis Feb 26, 2024 pm 07:48 PM

Interpretation der dynamischen SQL-Tags von MyBatis: Detaillierte Erläuterung der Verwendung von Set-Tags. MyBatis ist ein hervorragendes Persistenzschicht-Framework. Es bietet eine Fülle dynamischer SQL-Tags und kann Datenbankoperationsanweisungen flexibel erstellen. Unter anderem wird das Set-Tag zum Generieren der SET-Klausel in der UPDATE-Anweisung verwendet, die sehr häufig bei Aktualisierungsvorgängen verwendet wird. In diesem Artikel wird die Verwendung des Set-Tags in MyBatis ausführlich erläutert und seine Funktionalität anhand spezifischer Codebeispiele demonstriert. Was ist Set-Tag? Set-Tag wird in MyBati verwendet

So lösen Sie die PHP-Warnung: fopen(): Fehler beim Öffnen des Streams: Keine solche Datei oder kein solches Verzeichnis So lösen Sie die PHP-Warnung: fopen(): Fehler beim Öffnen des Streams: Keine solche Datei oder kein solches Verzeichnis Aug 19, 2023 am 10:44 AM

So lösen Sie PHPWarning:fopen():failedtoopenstream:Nosuchfileordirectory Bei der Verwendung von PHP-Entwicklung stoßen wir häufig auf einige Dateibetriebsprobleme, darunter „PHPWarning:fopen():failedtoopenstream:Nosuchfileordirectory“.

Lösung für PHP Schwerwiegender Fehler: Aufruf der undefinierten Funktion mysqli_connect() Lösung für PHP Schwerwiegender Fehler: Aufruf der undefinierten Funktion mysqli_connect() Jun 23, 2023 am 09:40 AM

Beim Schreiben von Webanwendungen mit PHP wird häufig eine MySQL-Datenbank zum Speichern von Daten verwendet. PHP bietet eine Möglichkeit zur Interaktion mit der MySQL-Datenbank namens MySQLi. Bei der Verwendung von MySQLi wird jedoch manchmal eine Fehlermeldung angezeigt, wie unten gezeigt: PHPFatalerror:Calltoundefinedfunctionmysqli_connect() Diese Fehlermeldung bedeutet, dass PHP my nicht finden kann

See all articles