AI智能
改变未来

Laravel 重写日志,让日志更优雅

更改目的:

  • 重写了日志格式
  • 加入trace,一次请求的唯一标识
  • 加入error级别信息推送,事例中使用企业微信群助手
  • 让我们可以更及时、更优雅、更方便追踪日志信息
  • 有助于初学者了解Laravel框架

1。将文件 AppTool.phpLogger.phpLogServiceProvider.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::registerCoreContainerAliaseslog信息修改。
如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 重写日志内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

  • laravel日志优化实例讲解
  • 解决laravel中日志权限莫名变成了root的问题
  • 关于laravel 日志写入失败问题汇总
  • 自定义Laravel (monolog)日志位置,并增加请求ID的实现
  • Laravel 5.5 异常处理 & 错误日志的解决
赞(0) 打赏
未经允许不得转载:爱站程序员基地 » Laravel 重写日志,让日志更优雅