TopLogger.php 965 B

12345678910111213141516171819202122232425262728293031323334353637
  1. <?php
  2. class TopLogger {
  3. public $conf
  4. = array(
  5. "separator" => "\t",
  6. "log_file" => ""
  7. );
  8. private $fileHandle;
  9. protected function getFileHandle() {
  10. if (null === $this->fileHandle) {
  11. if (empty($this->conf["log_file"])) {
  12. trigger_error("no log file spcified.");
  13. }
  14. $logDir = dirname($this->conf["log_file"]);
  15. if (!is_dir($logDir)) {
  16. mkdir($logDir, 0777, true);
  17. }
  18. $this->fileHandle = fopen($this->conf["log_file"], "a");
  19. }
  20. return $this->fileHandle;
  21. }
  22. public function log($logData) {
  23. if ("" == $logData || array() == $logData) {
  24. return false;
  25. }
  26. if (is_array($logData)) {
  27. $logData = implode($this->conf["separator"], $logData);
  28. }
  29. $logData = $logData."\n";
  30. fwrite($this->getFileHandle(), $logData);
  31. }
  32. }
  33. ?>