Heim >Backend-Entwicklung >PHP-Tutorial >Ausführliche Erläuterung, wie das Yii-Framework die Protokollierung in benutzerdefinierten Dateien implementiert

Ausführliche Erläuterung, wie das Yii-Framework die Protokollierung in benutzerdefinierten Dateien implementiert

*文
*文Original
2018-01-03 13:32:201592Durchsuche

Wie zeichnet das Yii-Framework Protokolle in benutzerdefinierten Dateien auf? In diesem Artikel wird hauptsächlich die Methode zum Aufzeichnen von Protokollen in benutzerdefinierten Dateien im Yii-Framework vorgestellt und die Prinzipien der Yii-Framework-Protokollierung sowie die damit verbundenen Konfigurations- und Implementierungsfähigkeiten der benutzerdefinierten Protokollierung anhand von Beispielen analysiert. Ich hoffe, es hilft allen.

Das Beispiel in diesem Artikel beschreibt, wie das Yii-Framework die Protokollierung in einer benutzerdefinierten Datei implementiert. Geben Sie es als Referenz an alle weiter. Die Details lauten wie folgt:

Standardmäßig zeichnet Yii::log($msg, $level, $category) das Protokoll in der Datei runtime/application.log auf.

Das Protokollformat ist wie folgt:

[Zeit] – [Ebene] – [Kategorie] – [Inhalt]

2013/05/03 17:33:08 [error] [application] test

Aber manchmal ist es notwendig, bestimmte Protokolle in bestimmte Dateien zu legen, B. Transaktionen. Fehlerprotokolle müssen getrennt von anderen Protokollen aufgezeichnet werden.

Dies kann durch die Konfiguration verschiedener CLogRouter in Yii gelöst werden.

Sie müssen zunächst den Protokollierungsmechanismus von Yii verstehen, der aus zwei Teilen besteht: CLogger und CLogRouter

CLogger ist für die Aufzeichnung von Protokolldaten im Speicher verantwortlich, während CLogRouter entscheidet, wie diese verarbeitet werden Protokolle. Daten, wie z. B. das Aufzeichnen in Dateien oder Datenbanken oder das Versenden von E-Mails usw.

Unter anderem wird CFileLogRoute zum Verarbeiten von Protokolldaten in Form von Dateien verwendet. Daher können Protokolle natürlich durch die Konfiguration verschiedener CFileLogRoutes in verschiedenen Protokolldateien aufgezeichnet werden.

Die spezifische Konfiguration ist wie folgt:

'log' => array(
  'class' => 'CLogRouter',
  'routes' => array(
    array(
      'class' => 'CFileLogRoute',
      'levels' => 'error, warning',
    ),
    array(
      'class' => 'CFileLogRoute',
      'levels' => 'error, warning',
      'categories'=> 'orders.*',
      'logFile'=> 'orders.log',
    ),

Wo Bestellfehler erfasst werden müssen, fügen Sie den folgenden Code hinzu:

Yii::log('your message', 'error', 'orders');

Verwandt Empfohlen:

Detaillierte Erläuterung der Eigenschaften in Yii

Detaillierte Erläuterung der YII-bezogenen Eigenschaften Abfrage

Formular im Yii-Framework

Das obige ist der detaillierte Inhalt vonAusführliche Erläuterung, wie das Yii-Framework die Protokollierung in benutzerdefinierten Dateien implementiert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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