Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法
本文实例讲述了laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法。分享给大家供大家参考,具体如下:
laravel中使用monolog_mysql将系统日志信息保存到mysql数据库
源码参考:
一、安装installation
在文件根目录:
composer require markhilton/monolog-mysql
发现composer.json文件里的"require"多了一行:
"markhilton/monolog-mysql": "^0.1.6",
如果执行报错检查php版本和laravel(5.5以上)版本,
或者可以自己手动粘贴"markhilton/monolog-mysql": "^0.1.6"
到composer.json上去,
然后执行:
compser update
可以达到相同的效果
成功后发现vendor里面多了一个markhilton的文件夹
二、在config/app.php 的'providers'里面加入
三、生成数据库文件
publish config using laravel artisan cli. php artisan vendor:publish
执行完上面语句发现database/migration里多了一个create_logs_table的文件
将文件重命名为 2018_03_14_034420_create_logs_table(一定要是这种格式的文件名才可以执行数据库迁移)
可以自定义数据库表名称,默认为logs ,在这里我改成sys_log
然后执行下面语句:
四、数据库迁移migrate tables.
php artisan migrate
生成了一个sys_log的表
五、应用集成 application integration
在bootstrap/app.php里面加入
$app->configuremonologusing(function($monolog) use($app) { $monolog->pushhandler(new logger\monolog\handler\mysqlhandler());});
六、配置环境 environment configuration
在.env的配置文件中加入(保存日志的数据库连接类型,以及保存日志的表名称)
db_log_table=sys_log //保存日志的数据库表名称 db_log_connection=mysql //保存日志的数据库连接类型
七、修改
真正实现将日志插入数据库的核心文件位置在:
/vendor/markhilton/monolog-mysql/src/logger/monolog/handler/mysqlhandler.php
将自定义的表名称修改为sys_log
<?php namespace logger\monolog\handler; use db; use illuminate\support\facades\auth; use monolog\logger; use monolog\handler\abstractprocessinghandler; class mysqlhandler extends abstractprocessinghandler { protected $table; protected $connection; public function __construct($level = logger::debug, $bubble = true) { $this->table = env('db_log_table', 'sys_log'); $this->connection = env('db_log_connection', env('db_connection', 'mysql')); parent::__construct($level, $bubble); } protected function write(array $record) { $data = [ 'instance' => gethostname(), 'message' => $record['message'], 'channel' => $record['channel'], 'level' => $record['level'], 'level_name' => $record['level_name'], 'context' => json_encode($record['context']), 'remote_addr' => isset($_server['remote_addr']) ? ip2long($_server['remote_addr']) : null, 'user_agent' => isset($_server['http_user_agent']) ? $_server['http_user_agent'] : null, 'created_by' => auth::id() > 0 ? auth::id() : null, 'created_at' => $record['datetime']->format('y-m-d h:i:s') ]; db::connection($this->connection)->table($this->table)->insert($data); } }
更多关于laravel相关内容感兴趣的读者可查看本站专题:《laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于laravel框架的php程序设计有所帮助。