handle with array/config/logger etc.
A application logger can extends Tlwl\Supports\Log and modify createLogger method, the method must return instance of Monolog\Logger.
use Tlwl\Supports\Logger;
use Monolog\Logger;
class ApplicationLogger extends Logger
{
/**
* Make a default log instance.
*
* @author tlwl <[email protected]>
*
* @return Logger
*/
public static function createLogger()
{
$handler = new StreamHandler('./log.log');
$handler->setFormatter(new LineFormatter("%datetime% > %level_name% > %message% %context% %extra%\n\n"));
$logger = new Logger('tlwl.private_number');
$logger->pushHandler($handler);
return $logger;
}
}Or, just init the log service with:
use Tlwl\Supports\Logger;
protected function registerLog()
{
$logger = Logger::createLogger($file, $identify, $level);
Logger::setLogger($logger);
}After registerLog, you can use Log service:
use Tlwl\Supports\Logger;
Logger::debug('test', ['test log']);