• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法

php 搞代码 4年前 (2022-01-01) 27次浏览 已收录 0个评论

这篇文章主要介绍了Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法,简单介绍了monolog_mysql的安装、配置、数据库迁移、日志生成、mysql写入等相关操作技巧,需要的朋友可以参考下

本文实例讲述了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_lo

来源gao!%daima.com搞$代*!码网

g

然后执行下面语句:

四、数据库迁移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

 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数据库的方法的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址