laravel的日志保存目录能不能不保存到 storage/logs 目录下?怎么修改?
可不可以自定义文件名?
按照文档配置按日期分割,不管用!还是在laravel.log 里面追加。
回复内容:
laravel的日志保存目录能不能不保存到 storage/logs 目录下?怎么修改?
可不可以自定义文件名?
按照文档配置按日期分割,不管用!还是在laravel.log 里面追加。
自定义日志
Method 1->简单粗暴
use Monolog\Handler\StreamHandler;
use Monolog\Logger;
$log = new Logger('vikin');
$log->pushHandler(
new StreamHandler(
storage_path('logs/vikin.log'),
Logger::INFO
)
);
$log->addInfo("test");
Method2->基于ConfigureLogging基类
1、可以使用该方法对laravel原有日志覆盖【一个info,其他级别可自行扩展】
2、作为一个laravel扩展,在需要单独记录日志的地方记录;
1、创建一个类,继承自ConfigureLogging
namespace 你自定义命名空间\ConfigureLogging;
use Illuminate\Foundation\Bootstrap\ConfigureLogging as BaseConfigureLogging;
use Monolog\Formatter\LineFormatter;
use Monolog\Handler\StreamHandler;
use Monolog\Logger;
class CustomLog extends BaseConfigureLogging
{
protected function configureSingleHandler(Application $app, Writer $log)
{
// 同方法1一样, 设置日志路径、设置日志级别
$path = storage_path('logs/vikin.log');
$level = Logger::INFO;
$logStreamHandler = new StreamHandler($path, $level);
// 日志格式:使用laravel原有格式:
// the default output format is "[%datetime%] %channel%.%level_name%: %message% %context% %extra%\n"
$format = "[%datetime%] %channel%.%level_name%: %message% %context% %extra%\n";
$formatter = new LineFormatter($format);
$logStreamHandler->setFormatter($formatter);
// 输出日志
$logger = $log->getMonolog();
$logger->pushHandler($logStreamHandler);
}
}
重写
configureSingleHandler就相当于重写了一个日志处理器;
尘月网络企业网站管理系统2010下载本版升级功能:1、增加“系统参数设置”功能,可在线管理编辑全站数据库路径、备份路径,无须到程序代码下更改;2、改进后台管理员权限分配问题,严谨、完善、安全的根限分配细分到每个功能页面的列表查看权限、添加权限、编辑权限、删除权限都可以在线分配,确保系统在多用户管理下,安全稳定运行;3、更新优化数据库操作,在线备份、压缩、恢复数据库,管理登录日志;4、增加&am
3、自动加载
修改根目录下的
composer.json文件
"psr-4": {
"App\\": "app/",
"你自定义命名空间\\": "文件路径/"
}
4、覆盖
在
/app/Http/Kernel.php文件中,扩展Kernel类的构造方法
use Illuminate\Contracts\Foundation\Application;
use Illuminate\Contracts\Events\Dispatcher;
public function __construct(Application $app, Dispatcher $events)
{
parent::__construct($app, $events);
array_walk($this->bootstrappers, function(&$bootstrapper)
{
if($bootstrapper === 'Illuminate\Foundation\Bootstrap\ConfigureLogging')
{
//替换为我们自定义的日志处理器
$bootstrapper = '你自定义命名空间\ConfigureLogging';
}
});
}
5、使用
Log::info('自定义log处理器');
6、扩展
创建一个ServiceProvider和facade(个人习惯喜欢使用facade);添加至app config中,使用composer自动加载即可;










