當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Handler\StreamHandler類代碼示例

本文整理匯總了PHP中Monolog\Handler\StreamHandler的典型用法代碼示例。如果您正苦於以下問題:PHP StreamHandler類的具體用法?PHP StreamHandler怎麽用?PHP StreamHandler使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了StreamHandler類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: initialize

 /**
  * Initialize the provider
  *
  * @return void
  */
 public function initialize()
 {
     $this->options = array_merge($this->defaultConfig, $this->options);
     date_default_timezone_set($this->options['log.timezone']);
     // Finally, create a formatter
     $formatter = new LineFormatter($this->options['log.outputformat'], $this->options['log.dateformat'], false);
     // Create a new directory
     $logPath = realpath($this->app->config('bono.base.path')) . '/' . $this->options['log.path'];
     if (!is_dir($logPath)) {
         mkdir($logPath, 0755);
     }
     // Create a handler
     $stream = new StreamHandler($logPath . '/' . date($this->options['log.fileformat']) . '.log');
     // Set our formatter
     $stream->setFormatter($formatter);
     // Create LogWriter
     $logger = new LogWriter(array('name' => $this->options['log.name'], 'handlers' => array($stream), 'processors' => array(new WebProcessor())));
     // Bind our logger to Bono Container
     $this->app->container->singleton('log', function ($c) {
         $log = new Log($c['logWriter']);
         $log->setEnabled($c['settings']['log.enabled']);
         $log->setLevel($c['settings']['log.level']);
         $env = $c['environment'];
         $env['slim.log'] = $log;
         return $log;
     });
     // Set the writer
     $this->app->config('log.writer', $logger);
 }
開發者ID:krisanalfa,項目名稱:b-comp,代碼行數:34,代碼來源:LogProvider.php

示例2: register

 public function register(Application $app)
 {
     //parent service provider activation
     $app->register(new MonologServiceProvider());
     //define default options
     $app['monolog.fingerscrossed.level'] = Logger::NOTICE;
     $app['monolog.fingerscrossed'] = true;
     $app['monolog.rotatingfile'] = false;
     $app['monolog.rotatingfile.maxfiles'] = 10;
     $app['monolog.fingerscrossed.handler'] = function () use($app) {
         $level = SuperMonologServiceProvider::translateLevel($app['monolog.level']);
         return new StreamHandler($app['monolog.logfile']);
     };
     //main override function
     $app['monolog.handler'] = function () use($app) {
         //setup level
         $Activationlevel = SuperMonologServiceProvider::translateLevel($app['monolog.fingerscrossed.level']);
         $level = SuperMonologServiceProvider::translateLevel($app['monolog.level']);
         //debug mode
         if ($app['debug']) {
             $handler = new StreamHandler($app['monolog.logfile'], $level);
             $handler->setFormatter(new \Ibsciss\Monolog\Formatter\LineFormatter());
             return $handler;
         }
         //if rotatingfile enable : figerscrossedHandler override
         if ($app['monolog.rotatingfile']) {
             $app['monolog.fingerscrossed.handler'] = new RotatingFileHandler($app['monolog.logfile'], $app['monolog.rotatingfile.maxfiles'], $level);
         }
         //apply default strategy
         $handler = $app['monolog.fingerscrossed'] ? new FingersCrossedHandler($app['monolog.fingerscrossed.handler'], $Activationlevel) : $app['monolog.fingerscrossed.handler'];
         $handler->setFormatter(new \Ibsciss\Monolog\Formatter\LineFormatter());
         return $handler;
     };
 }
開發者ID:ewake,項目名稱:supermonolog-service-provider,代碼行數:34,代碼來源:SuperMonologServiceProvider.php

示例3: write

 /**
  * 寫入日誌
  * @param $msg
  * @param $name
  * @param int $level
  * @param AbstractHandler $handler
  */
 public static function write($msg, $name, $level = Logger::INFO, AbstractHandler $handler = null)
 {
     $name .= '_' . $level;
     $name = $name . '_' . date('Y-m-d-H', Date::now());
     if (isset(self::$loggers[$name])) {
         $logger = self::$loggers[$name];
         if ($handler != null) {
             $logger->pushHandler($handler);
         }
     } else {
         $logger = new Logger($name);
         if ($handler == null) {
             $path = ConfigManager::get('log');
             $handler = new StreamHandler($path . DIRECTORY_SEPARATOR . $name . '.log', $level);
             $formatter = new LineFormatter(ConfigManager::get('log_formatter'), 'Y-m-d H:i:s');
             $handler->setFormatter($formatter);
         }
         $logger->pushHandler($handler);
         self::$loggers[$name] = $logger;
     }
     if (is_scalar($msg) === false) {
         $msg = json_encode($msg);
     }
     $logger->log($level, $msg);
 }
開發者ID:songsihan,項目名稱:simple,代碼行數:32,代碼來源:LogUtil.php

示例4: createLogger

 protected function createLogger($name)
 {
     $logger_title = "";
     if ($name == "_default_") {
         $logger_title = property_exists($this, "__log_title") ? $this->__log_title : "";
     }
     if ($name == "_default_") {
         $file = property_exists($this, "__log_file") ? storage_path("logs/" . $this->__log_file) : storage_path("logs/common.log");
     } else {
         if (strpos($name, "!") === 0) {
             $file = storage_path(str_replace("!", "", $name));
         } else {
             $file = storage_path("logs/" . $name . ".log");
         }
     }
     if (strpos($file, '%') !== false) {
         $file = str_replace("%d", date("Ymd"), $file);
     }
     if (!file_exists(dirname($file))) {
         mkdir(dirname($file));
     }
     $this->loggers[$name] = new Logger($logger_title, [], [new WebProcessor()]);
     $this->loggers[$name]->pushHandler($handler = new StreamHandler($file), Logger::INFO);
     $handler->setFormatter(new Formatter\LineFormatter(null, null, true, true));
 }
開發者ID:skvn,項目名稱:laraext,代碼行數:25,代碼來源:LoggerTrait.php

示例5: __construct

 /**
  * @param $functionname
  */
 public function __construct($resourcename)
 {
     //When the HTTP request didn't set a User Agent, set it to a blank
     if (!isset($_SERVER['HTTP_USER_AGENT'])) {
         $_SERVER['HTTP_USER_AGENT'] = '';
     }
     //Default timezone is Brussels
     date_default_timezone_set('Europe/Brussels');
     //This is the current resource that's handled. E.g., stations, connections, vehicleinfo or liveboard
     $this->resourcename = $resourcename;
     try {
         $this->log = new Logger('irapi');
         //Create a formatter for the logs
         $logFormatter = new LineFormatter("%context%\n", 'Y-m-d\\TH:i:s');
         $streamHandler = new StreamHandler(__DIR__ . '/../storage/irapi.log', Logger::INFO);
         $streamHandler->setFormatter($logFormatter);
         $this->log->pushHandler($streamHandler);
         $requestname = ucfirst(strtolower($resourcename)) . 'Request';
         include_once "requests/{$requestname}.php";
         $this->request = new $requestname();
         $this->dataRoot = new DataRoot($resourcename, $this->VERSION, $this->request->getFormat());
     } catch (Exception $e) {
         $this->buildError($e);
     }
 }
開發者ID:jncn,項目名稱:iRail,代碼行數:28,代碼來源:APICall.php

示例6: createStreamHandler

 /**
  * @return \Monolog\Handler\StreamHandler
  */
 protected function createStreamHandler()
 {
     $streamHandler = new StreamHandler(Config::get(LogConstants::LOG_FILE_PATH), Config::get(LogConstants::LOG_LEVEL, Logger::INFO));
     $formatter = new LogstashFormatter('Spryker');
     $streamHandler->setFormatter($formatter);
     return $streamHandler;
 }
開發者ID:spryker,項目名稱:Application,代碼行數:10,代碼來源:SprykerLoggerConfig.php

示例7: setUp

 /**
  * Set up test environment.
  */
 public function setUp()
 {
     parent::setUp();
     $this->link = new \MySQLi('localhost', 'root', '');
     if ($this->link->connect_error) {
         throw new \RuntimeException('Failed to connect to database. MySQL said: ' . $this->link->connect_error);
     }
     if (!$this->link->select_db('activecollab_jobs_queue_test')) {
         throw new \RuntimeException('Failed to select database.');
     }
     $this->connection = new MysqliConnection($this->link);
     $this->queue = new MySqlQueue($this->connection);
     $this->dispatcher = new Dispatcher($this->queue);
     $this->log_file_path = dirname(__DIR__) . '/logs/' . date('Y-m-d') . '.txt';
     if (is_file($this->log_file_path)) {
         unlink($this->log_file_path);
     }
     $this->log = new Logger('cli');
     $handler = new StreamHandler($this->log_file_path, Logger::DEBUG);
     $formatter = new LineFormatter();
     $formatter->includeStacktraces(true);
     $handler->setFormatter($formatter);
     $this->log->pushHandler($handler);
     $this->container = new Container(['dispatcher' => $this->dispatcher, 'log' => $this->log]);
 }
開發者ID:activecollab,項目名稱:jobsqueue,代碼行數:28,代碼來源:TestCase.php

示例8: register

 public function register(Container $app)
 {
     $app['logger'] = function () use($app) {
         return $app['monolog'];
     };
     if ($bridge = class_exists('Symfony\\Bridge\\Monolog\\Logger')) {
         $app['monolog.handler.debug'] = function () use($app) {
             $level = MonologServiceProvider::translateLevel($app['monolog.level']);
             return new DebugHandler($level);
         };
         if (isset($app['request_stack'])) {
             $app['monolog.not_found_activation_strategy'] = function () use($app) {
                 return new NotFoundActivationStrategy($app['request_stack'], array('^/'), $app['monolog.level']);
             };
         }
     }
     $app['monolog.logger.class'] = $bridge ? 'Symfony\\Bridge\\Monolog\\Logger' : 'Monolog\\Logger';
     $app['monolog'] = function ($app) {
         $log = new $app['monolog.logger.class']($app['monolog.name']);
         $handler = new Handler\GroupHandler($app['monolog.handlers']);
         if (isset($app['monolog.not_found_activation_strategy'])) {
             $handler = new Handler\FingersCrossedHandler($handler, $app['monolog.not_found_activation_strategy']);
         }
         $log->pushHandler($handler);
         if ($app['debug'] && isset($app['monolog.handler.debug'])) {
             $log->pushHandler($app['monolog.handler.debug']);
         }
         return $log;
     };
     $app['monolog.formatter'] = function () {
         return new LineFormatter();
     };
     $app['monolog.handler'] = $defaultHandler = function () use($app) {
         $level = MonologServiceProvider::translateLevel($app['monolog.level']);
         $handler = new Handler\StreamHandler($app['monolog.logfile'], $level, $app['monolog.bubble'], $app['monolog.permission']);
         $handler->setFormatter($app['monolog.formatter']);
         return $handler;
     };
     $app['monolog.handlers'] = function () use($app, $defaultHandler) {
         $handlers = array();
         // enables the default handler if a logfile was set or the monolog.handler service was redefined
         if ($app['monolog.logfile'] || $defaultHandler !== $app->raw('monolog.handler')) {
             $handlers[] = $app['monolog.handler'];
         }
         return $handlers;
     };
     $app['monolog.level'] = function () {
         return Logger::DEBUG;
     };
     $app['monolog.listener'] = function () use($app) {
         return new LogListener($app['logger'], $app['monolog.exception.logger_filter']);
     };
     $app['monolog.name'] = 'app';
     $app['monolog.bubble'] = true;
     $app['monolog.permission'] = null;
     $app['monolog.exception.logger_filter'] = null;
     $app['monolog.logfile'] = null;
     $app['monolog.use_error_handler'] = !$app['debug'];
 }
開發者ID:abdonor,項目名稱:silex_simple_api,代碼行數:59,代碼來源:MonologServiceProvider.php

示例9: getLogger

 /**
  * @return \Monolog\Logger
  */
 protected function getLogger()
 {
     $handler = new StreamHandler(storage_path('logs/api_request.log'), Logger::DEBUG);
     $handler->setFormatter(new LineFormatter(null, null, true, true));
     $logger = new Logger('ApiRequestLog');
     $logger->pushHandler($handler);
     return $logger;
 }
開發者ID:realshadow,項目名稱:satis-control-panel,代碼行數:11,代碼來源:ConfigManager.php

示例10: getLogger

 public function getLogger($logger)
 {
     $formatter = new LineFormatter();
     $stream = new StreamHandler($_SERVER['DOCUMENT_ROOT'] . "tomata/app/logs/tomata.log");
     $stream->setFormatter($formatter);
     $logger->pushHandler($stream, Logger::INFO);
     return $logger;
 }
開發者ID:tonialcaide,項目名稱:tomata,代碼行數:8,代碼來源:Util.php

示例11: getStreamHandlers

 /**
  * @param $logFolder
  *
  * @return StreamHandler[]
  */
 protected function getStreamHandlers($logFolder)
 {
     // create Monolog file stream
     $stream = new StreamHandler($logFolder . DIRECTORY_SEPARATOR . $this->getLogfileName());
     $stream->pushProcessor(array($this, 'streamProcessor'));
     $stream->setFormatter(new JSONFormatter());
     return [$stream];
 }
開發者ID:gavincsch,項目名稱:jsonlogger,代碼行數:13,代碼來源:Loggable.php

示例12: getLogger

 /**
  * @return \Monolog\Logger
  */
 public function getLogger()
 {
     $handler = new StreamHandler(storage_path('logs/builder_sync.log'), Logger::DEBUG);
     $handler->setFormatter(new LineFormatter(null, null, true, true));
     $logger = new Logger('SyncBuildLog');
     $logger->pushHandler($handler);
     return $logger;
 }
開發者ID:realshadow,項目名稱:satis-control-panel,代碼行數:11,代碼來源:SyncCommand.php

示例13: __construct

 private function __construct()
 {
     $fileName = sprintf('logs/hookbot-%s.log', Carbon::now()->format('Ymd'));
     $lineFormatter = new LineFormatter(null, null, true, true);
     $streamHandler = new StreamHandler(storage_path($fileName), MonoLogger::DEBUG);
     $streamHandler->setFormatter($lineFormatter);
     $this->logger = new MonoLogger('HookBot', [$streamHandler]);
 }
開發者ID:jshayes,項目名稱:hookbot,代碼行數:8,代碼來源:Logger.php

示例14: createChannel

 /**
  * @param string $channel
  * @param string $level
  */
 private function createChannel($channel, $level)
 {
     $fileName = $this->appPath->getCacheDir() . 'logs/' . $channel . '.log';
     $logLevelConst = constant(\Monolog\Logger::class . '::' . strtoupper($level));
     $stream = new StreamHandler($fileName, $logLevelConst);
     $stream->setFormatter(new LineFormatter(null, null, true));
     $this->channels[$channel] = new \Monolog\Logger($channel, [$stream]);
 }
開發者ID:acp3,項目名稱:core,代碼行數:12,代碼來源:Logger.php

示例15: registerLogging

 public function registerLogging()
 {
     $formatter = new LineFormatter(null, null, true, true);
     $stream = new StreamHandler(logdir() . 'error.log', Logger::ERROR);
     $stream->setFormatter($formatter);
     $this->log = new Logger('default');
     $this->log->pushHandler($stream);
 }
開發者ID:JanFoerste,項目名稱:blivy,代碼行數:8,代碼來源:Exception.php


注:本文中的Monolog\Handler\StreamHandler類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。