首頁 >後端開發 >php教程 >php自訂函數記錄log日誌

php自訂函數記錄log日誌

小云云
小云云原創
2018-02-06 09:28:331927瀏覽

本文主要和大家分享php基於自訂函數記錄log日誌方法,涉及php針對文件、目錄及錯誤日誌相關操作技巧,需要的朋友可以參考下,希望能幫助到大家。


/**
 * 记录错误日志
 * @param 日志内容 $res
 */
function save_log($res) {
  $err_date = date("Ym", time());
  //$address = '/var/log/error';
  $address = './error';
  if (!is_dir($address)) {
    mkdir($address, 0700, true);
  }
  $address = $address.'/'.$err_date . '_error.log';
  $error_date = date("Y-m-d H:i:s", time());
  if(!empty($_SERVER['HTTP_REFERER'])) {
    $file = $_SERVER['HTTP_REFERER'];
  } else {
    $file = $_SERVER['REQUEST_URI'];
  }
  if(is_array($res)) {
    $res_real = "$error_date\t$file\n";
    error_log($res_real, 3, $address);
    $res = var_export($res,true);
    $res = $res."\n";
    error_log($res, 3, $address);
  } else {
    $res_real = "$error_date\t$file\t$res\n";
    error_log($res_real, 3, $address);
  }
}

var_export() 方法詳解:

var_export – 輸出或傳回一個變數的字串表示

#描述:

mixed var_export ( mixed expression , bool )

此函數傳回傳遞給該函數的變數的結構訊息,它和var_dump() 類似,不同的是其傳回的表示是合法的PHP 程式碼。

您可以將函數的第二個參數設為 TRUE,從而傳回變數的表示。

EG:

var_export(array('a','b',array('aa','bb','cc'))) 這種與VAR_DUMP沒什麼區別;


$var =var_export(array('a','b',array('aa','bb','cc')),TRUE)

加上TRUE後,不會再印出來,

而是給了一個變量,這樣就可以直接輸出;


echo $var;

此時輸出來的形式與var_dump()列印的相似。

相關推薦:

yii2中關於log輸出到file及database的簡單實例


以上是php自訂函數記錄log日誌的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn