Как я могу реализовать "дамп объекта" с log4php? - PullRequest
3 голосов
/ 14 мая 2011

Я сейчас нахожусь в процессе перехода от нашего собственного проприетарного решения для ведения журнала к log4php в одном из наших проектов.Наше собственное решение имеет вспомогательный метод, который я разместил ниже.Цель метода - записать содержимое переменной (и любого из ее членов рекурсивно) в журнал.

Эквивалентным местом для этого метода в log4php будет класс Logger (я полагаю).Но мне интересно, как правильно интегрировать эту функциональность.

Должен ли я просто использовать Logger и расширять его?Или есть способ «подключить» эту функцию.

Заранее спасибо.

/**
* Dump the complete content of the target object to the log.
*
* @param mixed $target The object to dump.
* @param int $level The verbosity level.
* @param int $indent Indentation level.
*/
public static function dump( $target, $level = Logging::eDEBUG, $indent = 0 ) {
  if( $level < self::getInstance()->logLevel ) return;

  if( null == $target ) {
    self::log( "d", "> " . str_repeat( "\t", $indent ) . "null", $level );
    return;
  }

  if( is_string( $target ) || is_numeric( $target ) ) {
    self::log( "d", "> " . str_repeat( "\t", $indent ) . $target, $level );
    return;
  }

  foreach( $target as $key => $value ) {
    if( is_array( $value ) ) {
      self::log( "d", "> " . str_repeat( "\t", $indent ) . $key . " -> Array (", $level );
      self::dump( $value, $level, $indent + 1 );
      self::log( "d", "> " . str_repeat( "\t", $indent ) . ")", $level );
      continue;
    }

    if( is_object( $value ) ) {
      self::log( "d", "> " . str_repeat( "\t", $indent ) . $key . " -> Object (", $level );
      self::dump( (array)$value, $level, $indent + 1 );
      self::log( "d", "> " . str_repeat( "\t", $indent ) . ")", $level );

    } else {
      self::log( "d", "> " . str_repeat( "\t", $indent ) . $key . " -> " . $value, $level );
    }
  }
} 

1 Ответ

2 голосов
/ 14 мая 2011

Все это объясняется в log4php документах .

...