《PHP學習:PHP如何將log信息寫入服務器中的log文件》要點:
本文介紹了PHP學習:PHP如何將log信息寫入服務器中的log文件,希望對您有用。如果有疑問,可以聯系我們。
PHP實戰將log信息寫入服務器中的log文件文件,折騰了一大圈終于找到了辦理方案,具體內容如下:
PHP實戰折騰:
PHP實戰【記錄】php中如何寫類和如何使用類
PHP實戰期間,必要整理出一份,可配置的,通用的,log系統.
PHP實戰支持寫入log信息到log文件中.
PHP實戰【折騰過程】
PHP實戰1.搜:
PHP實戰php log to file
PHP實戰參考:
PHP實戰PHP: error_log C Manual
PHP實戰PHP: syslog C Manual
PHP實戰How to create logs with PHP C Web Services Wiki
PHP實戰Write to a log file with PHP | Redips spideR Net
PHP實戰下載代碼:
PHP實戰Download redips10.tar.gz
PHP實戰2.期間:
PHP實戰【已辦理】PHP中函數前面加上at符號@的作用
PHP實戰3.然后用代碼:
PHP實戰
crifanLib.php
<?php
/*
[Filename]
crifanLib.php
[Function]
crifan's php lib, implement common functions
[Author]
Crifan Li
[Contact]
http://www.crifan.com/contact_me/
[Note]
1.online see code:
http://code.google.com/p/crifanlib/source/browse/trunk/php/crifanLib.php
[TODO]
[History]
[v1.0]
1.initial version, need clean up later
*/
class crifanLib {
private $logFile;
private $logFp;
/*
Init log file
*/
function logInit($inputLogFile = null){
// set default log file name
// in case of Windows set default log file
//http://stackoverflow.com/questions/1482260/how-to-get-the-os-on-which-php-is-running
//http://php.net/manual/zh/function.php-uname.php
if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
$defautLogFile = 'C:/php/defLogFile.log';
}
// set default log file for Linux and other systems
else {
$defautLogFile = '/tmp/defLogFile.log';
}
$this->logFile = $inputLogFile ? $inputLogFile : $defautLogFile;
// open log file for writing only and place file pointer at the end of the file
// (if the file does not exist, try to create it)
$this->logFp = fopen($this->logFile, 'a') or exit("Can't open $this->logFile!");
}
/*
Write log info to file
*/
function logWrite($logContent){
// if file pointer doesn't exist, then open log file
if (!is_resource($this->logFp)) {
$this->logInit();
}
// define script name
$script_name = pathinfo($_SERVER['PHP_SELF'], PATHINFO_FILENAME);
// define current time and suppress E_WARNING if using the system TZ settings
// (don't forget to set the INI setting date.timezone)
$time = @date('[Y-m-d H:i:s] ');
// write current time, script name and message to the log file
fwrite($this->logFp, "$time ($script_name) $logContent" . PHP_EOL);
}
/*
Deinit log
*/
function logDeinit(){
if (is_resource($this->logFp)) {
fclose($this->logFp);
}
}
}
?>
PHP實戰然后測試代碼:
PHP實戰
<?php
/*
Author: Crifan Li
Version: 2015-07-27
Contact: http://www.crifan.com/about/me/
Function: Wechat get access token
*/
include_once "crifanLib.php";
//test log
$crifanLib = new crifanLib();
$crifanLib->logInit("/xxx/access_token/crifanLibTest.log");
$crifanLib->logWrite("This is crifanLib log test message.");
$crifanLib->logDeinit();
?>
PHP實戰
然后去執行對應的代碼:
PHP實戰http://xxx/access_token/wx_access_token.php
PHP實戰頁面是沒有任何輸出的:
PHP實戰
PHP實戰然后的確生成了log文件了:
PHP實戰
root@chantyou:php# cd access_token/
root@chantyou:access_token# ll
total 16
-rwxrwxrwx 1 root root 9335 Jul 27 17:51 crifanLib.php
-rwxrwxrwx 1 root root 567 Jul 27 17:52 wx_access_token.php
root@chantyou:access_token# ll
total 20
-rwxrwxrwx 1 root root 9335 Jul 27 17:51 crifanLib.php
-rw-r--r-- 1 apache apache 77 Jul 27 17:56 crifanLibTest.log
-rwxrwxrwx 1 root root 567 Jul 27 17:52 wx_access_token.php
root@chantyou:access_token# cat crifanLibTest.log
[2015-07-27 10:10:33] (wx_access_token) This is crifanLib log test message.
root@chantyou:access_token#
PHP實戰【注意】
PHP實戰要記得給對應的(此處是Linux服務器中的對應的文件夾添加寫權限:
PHP實戰
root@chantyou:php# ll
total 48
drwxr-xr-x 2 root root 4096 Jul 27 17:55 access_token
-rwxr-xr-x 1 root root 1091 Sep 25 2014 errorCode.php
-rw-r--r-- 1 root root 2230 Jun 10 14:16 MicromsgVerify.php
-rwxr-xr-x 1 root root 4288 Sep 25 2014 pkcs7Encoder.php
-rwxr-xr-x 1 root root 452 Sep 15 2014 Readme.txt
-rwxr-xr-x 1 root root 724 Sep 22 2014 sha1.php
drwxr-xr-x 2 root root 4096 Jul 20 12:34 wechat_encypt
-rwxr-xr-x 1 root root 5327 Sep 15 2014 WXBizMsgCrypt.php
-rwxrwxrwx 1 root root 2455 Jul 16 18:06 wx_didaosuzhou.php
-rwxr-xr-x 1 root root 1346 Sep 22 2014 xmlparse.php
root@chantyou:php# chmod ugo+wx access_token/
root@chantyou:php# ll
total 48
drwxrwxrwx 2 root root 4096 Jul 27 17:55 access_token
-rwxr-xr-x 1 root root 1091 Sep 25 2014 errorCode.php
-rw-r--r-- 1 root root 2230 Jun 10 14:16 MicromsgVerify.php
-rwxr-xr-x 1 root root 4288 Sep 25 2014 pkcs7Encoder.php
-rwxr-xr-x 1 root root 452 Sep 15 2014 Readme.txt
-rwxr-xr-x 1 root root 724 Sep 22 2014 sha1.php
drwxr-xr-x 2 root root 4096 Jul 20 12:34 wechat_encypt
-rwxr-xr-x 1 root root 5327 Sep 15 2014 WXBizMsgCrypt.php
-rwxrwxrwx 1 root root 2455 Jul 16 18:06 wx_didaosuzhou.php
-rwxr-xr-x 1 root root 1346 Sep 22 2014 xmlparse.php
PHP實戰否則會報錯的:
PHP實戰Can't open /xxx/access_token/crifanLibTest.log file!
PHP實戰4.不過突然想起來:
PHP實戰之前已經學過了,
PHP實戰file_put_contents
PHP實戰就可以替代了:fopen,fwrite,fclose了.
PHP實戰所以再去優化為:
PHP實戰crifanLib.php
PHP實戰
<?php
/*
[Filename]
crifanLib.php
[Function]
crifan's php lib, implement common functions
[Author]
Crifan Li
[Contact]
http://www.crifan.com/contact_me/
[Note]
1.online see code:
http://code.google.com/p/crifanlib/source/browse/trunk/php/crifanLib.php
[TODO]
[History]
[v2015-07-27]
1.add logInit, logWrite
[v1.0]
1.initial version, need clean up later
*/
class crifanLib {
private $logFile;
private $logFp;
/*
Init log file
*/
function logInit($inputLogFile = null){
// set default log file name
// in case of Windows set default log file
//http://stackoverflow.com/questions/1482260/how-to-get-the-os-on-which-php-is-running
//http://php.net/manual/zh/function.php-uname.php
if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
$defautLogFile = 'C:/php/defLogFile.log';
}
// set default log file for Linux and other systems
else {
$defautLogFile = '/tmp/defLogFile.log';
}
$this->logFile = $inputLogFile ? $inputLogFile : $defautLogFile;
}
/*
Write log info to file
*/
function logWrite($logContent){
// define script name
$scriptName = pathinfo($_SERVER['PHP_SELF'], PATHINFO_FILENAME);
// define current time and suppress E_WARNING if using the system TZ settings
// (don't forget to set the INI setting date.timezone)
$timeStr = @date('[Y-m-d H:i:s]');
// write current time, script name and message to the log file
file_put_contents($this->logFile, "$timeStr ($scriptName) $logContent" . PHP_EOL, FILE_APPEND);
}
}
?>
PHP實戰
測試文件為:
PHP實戰
<?php
/*
Author: Crifan Li
Version: 2015-07-27
Contact: http://www.crifan.com/about/me/
Function: test crifanLib log
*/
include_once "crifanLib.php";
//test log
$crifanLib = new crifanLib();
$crifanLib->logInit("/xxx/logTest.log");
$crifanLib->logWrite("This is crifanLib log test message using file_put_contents");
?>
PHP實戰效果是:
PHP實戰root@chantyou:access_token# ll
total 16
-rw-r--r-- 1 root root 9524 Jul 27 18:16 crifanLib.php
-rwxrwxrwx 1 root root? 561 Jul 27 18:18 wx_access_token.php
root@chantyou:access_token# ll
total 20
-rw-r--r-- 1 root?? root?? 9524 Jul 27 18:16 crifanLib.php
-rw-r--r-- 1 apache apache?? 76 Jul 27 18:19 logTest.log
-rwxrwxrwx 1 root?? root??? 561 Jul 27 18:18 wx_access_token.php
root@chantyou:access_token# cat logTest.log
[2015-07-27 12:05:47] (wx_access_token) This is crifanLib log test message using file_put_contents
root@chantyou:access_token#
如圖:
PHP實戰
PHP實戰注:
PHP實戰期間參考:
PHP實戰PHP: is_resource C Manual
PHP實戰【總結】
PHP實戰1.此處可以通過:
PHP實戰fopen創建log文件
fwrite寫入文件信息
fclose關閉文件
去實現log信息寫入到文件中的.
PHP實戰2.更好的做法是:
PHP實戰直接用更便利的
PHP實戰file_put_contents直接輸出內容到log文件
即可.
PHP實戰以上便是將log信息寫入服務器中的log文件文件全部內容,希望大家喜歡.
《PHP學習:PHP如何將log信息寫入服務器中的log文件》是否對您有啟發,歡迎查看更多與《PHP學習:PHP如何將log信息寫入服務器中的log文件》相關教程,學精學透。維易PHP學院為您提供精彩教程。
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/9381.html