Yii 日志记录
Yii提供了一个高度可定制和可扩展的框架。借助这个框架,您可以轻松地记录各种类型的消息。
要记录一条消息,您应该调用以下方法之一−
- Yii::error() − 记录一个致命错误消息。
-
Yii::warning() − 记录一个警告消息。
-
Yii::info() − 记录一条带有一些有用信息的消息。
-
Yii::trace() − 记录一条消息以跟踪代码片段的运行情况。
上述方法在各个类别记录日志消息。它们共享以下函数签名−
其中−
- $message − 要记录的日志消息
-
$category − 日志消息的类别
一个简单而便利的命名方案是使用PHP的METHOD魔术常量。例如 −
日志目标是 yii\log\Target 类的一个实例。它通过类别筛选所有日志消息,并将它们导出到文件、数据库和/或电子邮件。
步骤1 - 您也可以注册多个日志目标,例如:
在上面的代码中,注册了两个目标。第一个目标选择所有错误、警告、跟踪和信息消息,并将它们保存在数据库中。第二个目标将所有错误和警告消息发送到管理员的邮箱。
Yii提供了以下内置的日志目标:
- yii\log\DbTarget - 将日志消息存储在数据库中。
-
yii\log\FileTarget - 将日志消息保存在文件中。
-
yii\log\EmailTarget - 将日志消息发送到预定义的电子邮件地址。
-
yii\log\SyslogTarget - 通过调用PHP函数syslog()将日志消息保存到syslog中。
默认情况下,日志消息的格式如下:
步骤2 − 要自定义这个格式,您应该配置 yii\log\Target::$prefix 属性。例如。
上面的代码片段配置了一个日志目标,以当前用户ID作为所有日志消息的前缀。
默认情况下,日志消息包括以下全局PHP变量的值:_POST,_COOKIE,_SERVER。要修改此行为,您应该使用变量名配置yii\log\Target::$logVars属性,这些变量希望包含在内。
所有日志消息都由日志记录器对象维护在一个数组中。日志记录器对象将记录的消息刷新到日志目标中,每当数组累积一定数量的消息时(默认为1000次)。
步骤3 - 要自定义此数量,您应该调用 flushInterval属性 。
即使日志记录器对象将日志消息刷新到日志目标,它们也不会立即导出。导出发生在日志目标积累了一定数量的消息时(默认值为1000)。
步骤4 - 要自定义此数字,您应该配置 exportInterval 属性。
步骤5 − 现在,以这种方式修改 config/web.php 文件。
在上面的代码中,我们定义了日志应用组件,将 flushInterval 和 exportInteval 属性设置为1,以便所有日志消息立即显示在日志文件中。我们还省略了日志目标的levels属性。这意味着所有类别(error,warning,info,trace)的日志消息都会出现在日志文件中。
步骤6 - 然后,在SiteController中创建一个名为actionLog()的函数。
在上面的代码中,我们只是将四个不同类别的日志消息写入日志文件中。
步骤7 - 在浏览器的地址栏中输入 http://localhost:8080/index.php?r=site/log ,日志消息应出现在app/runtime/logs目录下的app.log文件中。