Heim >Backend-Entwicklung >PHP-Tutorial >Ausführliche Erläuterung, wie das Yii-Framework die Protokollierung in benutzerdefinierten Dateien implementiert
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
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!