php 구현 debug 로그 작업 클래스 인 스 턴 스

1867 단어 phplog로그
이 실례 는 php 가 실현 한 debug 로그 작업 클래스 를 설명 합 니 다.여러분 께 참고 하도록 공유 하 겠 습 니 다.구체 적 으로 는 다음 과 같 습 니 다.

<?php
class Tool {
  public static function log($info) {
    $time = date('m-d H:i:s');
    $backtrace = debug_backtrace();
    $backtrace_line = array_shift($backtrace); //       log  
    $backtrace_call = array_shift($backtrace); //     log  
    $file = substr($backtrace_line['file'], strlen($_SERVER['DOCUMENT_ROOT']));
    $line = $backtrace_line['line'];
    $class = isset($backtrace_call['class']) ? $backtrace_call['class'] : '';
    $type = isset($backtrace_call['type']) ? $backtrace_call['type'] : '';
    $func = $backtrace_call['function'];
    file_put_contents($_SERVER['DOCUMENT_ROOT'].'/debug.log', "$time $file:$line $class$type$func: $info
", FILE_APPEND); } } class Action { public function a() { $this->b(); } public function b() { $this->c(); } public function c() { Tool::log('sdfsdf'); } } $action = new Action(); $action->a();
여기에 함 수 를 하나 더 추가 합 니 다.

function loginfo($format) {
  $args = func_get_args();
  array_shift($args);
  $d = debug_backtrace(DEBUG_BACKTRACE_PROVIDE_OBJECT, 1)[0];
  $info = vsprintf($format, $args);
  $data = sprintf("%s %s,%d: %s
", date("Ymd His"), $d["file"], $d["line"], $info); file_put_contents(__DIR__."/log.txt", $data, FILE_APPEND); }
더 많은 PHP 관련 내용 에 관심 이 있 는 독자 들 은 본 사이트 의 주 제 를 볼 수 있다.
본 논문 에서 말 한 것 이 여러분 의 PHP 프로 그래 밍 에 도움 이 되 기 를 바 랍 니 다.

좋은 웹페이지 즐겨찾기