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);
}
}
Method 1->简单粗暴
Method2->基于ConfigureLogging基类
1、创建一个类,继承自ConfigureLogging
3、自动加载
4、覆盖
5、使用
6、扩展