时间:2021-05-26
更改目的:
1。将文件 AppTool.php、Logger.php、LogServiceProvider.php复制到 app/Providers文件夹下,将文件BaseCommand.php复制到App\Console下
2 。在config/app.php→providers中加入
'providers' => [ …… // 注册日志 App\Providers\LogServiceProvider::class …… ];3。在项目中使用如下方式调用
// php-fpm方式调用 日志路径 /opt/logs/xxx.log /opt/logs/xxx.error\Log::info("info");\Log::debug("debug");\Log::error("error");// 在cli方式调用 日志路径 /opt/clogs/xxx.log /opt/clogs/xxx.errorapp('cLog')->info("info");app('cLog')->debug("debug");app('cLog')->error("error");4。在日志级别为error时,会执行推送,本事例中采用企业微信群推送
/** * 推送错误信息 * @param $message */ public function pushErrorMessage($message) { $content = "app:". static::getAppName() ." src: ". static::getRequestSource() ."trace:". self::getTrace() ."url:". static::$uri_info ." error: ". $message ."time:". date("Y-m-d H:i:s"); // 测试群 $url = "xxxxxxxxxxxx"; $result = app('\GuzzleHttp\Client')->request('POST', $url, [ \GuzzleHttp\RequestOptions::JSON=>[ "msgtype"=> "text", "text"=> [ "content" => $content ] ] ]); $body = \GuzzleHttp\json_decode($result->getBody()->getContents(), true); }5 。日志内容
注意事项:
修改如下代码不同版本bind部分会有所不同,具体根据\Illuminate\Foundation\Application::registerCoreContainerAliases中log信息修改。
如laravel6.x中为'log' => [\Illuminate\Log\LogManager::class, \Psr\Log\LoggerInterface::class],,
修改方式就如下方代码
…… // 注入全局容器 $app->instance('Log', $logger); $app->bind('Psr\Log\LoggerInterface', function (Application $app) { return $app['log']->getLogger(); }); $app->bind('\Illuminate\Log\LogManager', function (Application $app) { return $app['log']; }); ……有关console中使用时,建议重写\Illuminate\Console\Command::info、\Illuminate\Console\Command::line、\Illuminate\Console\Command::error,然后所有console继承BaseCommanddemo代码块:use App\Console\BaseCommand;class Demo extends BaseCommand{ protected $signature = 'command:demo'; protected $description = 'demo'; public function __construct() { parent::__construct(); } public function handle() { $this->info('this is info!'); $this->line('this is line!'); $this->error('this is error!!!'); }}demo 命令行输出:
到此这篇关于Laravel 重写日志,让日志更优雅的文章就介绍到这了,更多相关Laravel 重写日志内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
shell脚本如何优雅的记录日志信息,下面让我们一步一步,让shell脚本的日志也变得高端起来,实现如下功能①设定日志级别,实现可以输出不同级别的日志信息,方便
本文实例讲述了Laravel日志用法。分享给大家供大家参考,具体如下:这里使用的Laravel版本仍是5.2日志是非常重要的。本地开发可以开启调试模式,但是上线
python多进程下实现日志记录按时间分割,供大家参考,具体内容如下原理:自定义日志handler继承TimedRotatingFileHandler,并重写c
通过logging模块,重写一个logging2模块,独立开启线程,将待写的日志信息异步放入队列,做到日志输出不影响主流程性能,环境python3.8loggi
MongoDB实用场景产品用户访问日志,点击埋点统计信息业务系统环境参数配置信息业务系统运行时日志,如laravel.log,nginx.log使用Homebr