Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3032字,纯文字阅读大概需要5分钟。
内容图文
本文实例讲述了Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法。分享给大家供大家参考,具体如下:
Laravel中使用monolog_mysql将系统日志信息保存到mysql数据库
源码参考: https://github.com/markhilton/monolog-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'里面加入
代码如下:'providers' => array( // ... Logger\Laravel\Provider\MonologMysqlHandlerServiceProvider::class,);
三、生成数据库文件
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程序设计有所帮助。
内容总结
以上是互联网集市为您收集整理的Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法全部内容,希望文章能够帮你解决Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。