您好,登錄后才能下訂單哦!
小編給大家分享一下PHP如何記錄和讀取JSON格式日志文件,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
PHP寫日志文件
PHP寫日志文件需要打開、寫入和關閉文件等操作,PHP有fopen(),fwrite()和fclose()三個函數與之對應,而另一個函數file_put_contents()它也能字符串寫入文件,其實這個函數實現了依次調用 fopen(),fwrite() 以及 fclose()。所以我們使用file_put_contents()非常簡潔。值得注意的是,往文件后面追加內容時需要帶上參數:FILE_APPEND。
實際運行中,我們有可能會遇到日志文件超大的情況,所以我們設置一個最大值,當日志文件大小超過這個最大值時,將此日志文件備份好,然后重新生成一個新的日志文件來記錄新的日志內容。
在寫日志前,我們將日志內容進行json格式化,所以需要將內容轉化成JSON格式,然后寫入文件。當然你也可以不用json,或者換作別的工具程序(如日志分析工具)可以閱讀的格式。總之,我們寫入的內容是方便必要時可以方便讀取。
function writeLog($filename,$msg){ $res = array(); $res['msg'] = $msg; $res['logtime'] = date("Y-m-d H:i:s",time()); //如果日志文件超過了指定大小則備份日志文件 if(file_exists($filename) && (abs(filesize($filename)) > 1024000)){ $newfilename = dirname($filename).'/'.time().'-'.basename($filename); rename($filename, $newfilename); } //如果是新建的日志文件,去掉內容中的第一個字符逗號 if(file_exists($filename) && abs(filesize($filename))>0){ $content = ",".json_encode($res); }else{ $content = json_encode($res); } //往日志文件內容后面追加日志內容 file_put_contents($filename, $content, FILE_APPEND); }
PHP讀日志文件
必要時,我們會讀取日志內容進行分析,同樣我們使用PHP的file_get_contents()函數,直接將內容讀取,并且轉換成json格式,方便調用。
function readLog($filename){ if(file_exists($filename)){ $content = file_get_contents($filename); $json = json_decode('['.$content.']',true); }else{ $json = '{"msg":"The file does not exist."}'; } return $json; }
日志寫入和讀取類
寫入和讀取日志的功能我們經常要用到,所以我將寫入和讀取功能整理成類,方便調用。
<?php /* * 日志類 * 每天生成一個日志文件,當文件超過指定大小則備份日志文件并重新生成新的日志文件 */ class Log { private $maxsize = 1024000; //最大文件大小1M //寫入日志 public function writeLog($filename,$msg){ $res = array(); $res['msg'] = $msg; $res['logtime'] = date("Y-m-d H:i:s",time()); //如果日志文件超過了指定大小則備份日志文件 if(file_exists($filename) && (abs(filesize($filename)) > $this->maxsize)){ $newfilename = dirname($filename).'/'.time().'-'.basename($filename); rename($filename, $newfilename); } //如果是新建的日志文件,去掉內容中的第一個字符逗號 if(file_exists($filename) && abs(filesize($filename))>0){ $content = ",".json_encode($res); }else{ $content = json_encode($res); } //往日志文件內容后面追加日志內容 file_put_contents($filename, $content, FILE_APPEND); } //讀取日志 public function readLog($filename){ if(file_exists($filename)){ $content = file_get_contents($filename); $json = json_decode('['.$content.']',true); }else{ $json = '{"msg":"The file does not exist."}'; } return $json; } } ?>
使用方法:
$filename = "logs/log_".date("Ymd",time()).".txt"; $msg = '寫入了日志'; $Log = new Log(); //實例化 $Log->writeLog($filename,$msg); //寫入日志 $loglist = $Log->readLog($filename); //讀取日志
以上是“PHP如何記錄和讀取JSON格式日志文件”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。