Heim  >  Artikel  >  Backend-Entwicklung  >  Verwenden Sie debug_backtrace, um eine grundlegende Protokolldruckfunktion anzupassen (PHP-Codebeispiel).

Verwenden Sie debug_backtrace, um eine grundlegende Protokolldruckfunktion anzupassen (PHP-Codebeispiel).

藏色散人
藏色散人nach vorne
2021-05-31 09:39:392638Durchsuche

Verwenden Sie debug_backtrace, um eine grundlegende Protokolldruckfunktion anzupassen (PHP-Codebeispiel).Kürzlich habe ich einen alten Ahnencode geändert, aber leider hatte er nicht einmal eine Protokolldruckfunktion und es gab keine Framework-Unterstützung, sodass mir klar wurde, wie schwach ich war.

Empfohlen: „

PHP-Video-Tutorial

Als ich mir den Code anderer Leute ansah, entdeckte ich, dass die PHP-Funktion debug_backtrace() mein Problem wirklich gelöst hat. Sie können eine Funktion definieren, um den Dateinamen und die Zeile aufzuzeichnen, wenn die Die Funktion wird aufgerufen, um die entsprechende Druckposition zu ermitteln.

/**
 * 自定义日志打印,将日志信息写入指定文件,并记录当前调用的文件名与行数
 * @param $data mixed 写入文件的数据
 * @param $file string 文件路径
 */
function put_log($data,$file){

    // 递归创建文件夹
    function created_dir( $dir ){
        return  is_dir ( $dir ) or created_dir(dirname( $dir )) and  mkdir ( $dir , 0777);
    }

    $traces = debug_backtrace();

    if(dirname($file)!='.'){
        created_dir( dirname($file) );
    }

    $str = date('Y-m-d H:i:s')."\n";
    foreach ($traces as $trace){
        $str .= $trace["file"]." 文件第【".$trace["line"]."】行 data:\n";
    }
    $str .= json_encode($data)."\n\n";

    file_put_contents($file,$str,FILE_APPEND);
}

put_log('sss','ss/s/a.txt');

Das obige ist der detaillierte Inhalt vonVerwenden Sie debug_backtrace, um eine grundlegende Protokolldruckfunktion anzupassen (PHP-Codebeispiel).. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:learnku.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen