記錄php日誌,php日誌框架

本文目錄一覽:

php該在哪裡寫日誌?怎麼寫日誌?日誌是做什麼用的?

所謂的日誌就是記錄系統運行狀態的數據。

一般是將信息記錄到文本文件或數據庫中。

比如:

?php

function writeLog($msg){

$logFile = date(‘Y-m-d’).’.txt’;

$msg = date(‘Y-m-d H:i:s’).’ ‘.$msg.”\r\n”;

file_put_contents($logFile,$msg,FILE_APPEND );

}

//調用上面的函數,寫一條信息進日誌文件

writeLog(‘這是測試日誌信息’);

?

nginx php-fpm記錄php錯誤日誌怎麼配置

要想讓php-fpm顯示錯誤日誌,首先需要配置php-fpm。

在php-fpm的配置文件中(一般位於php安裝目錄下的etc/php-fpm.conf)配置php錯誤日誌的文件路徑。

1

2

3

4

5

6

; Error log file

; If it’s set to “syslog”, log is sent to syslogd instead of being written

; in a local file.

; Note: the default prefix is /home/wangwei/php/var

; Default Value: log/php-fpm.log

;error_log = log/php-fpm.log

如上是我的php-fpm.conf文件中配置錯誤日誌的地方。把error_log = log/php-fpm.log之前的;去掉,然後修改為:

1

2

3

4

5

6

; Error log file

; If it’s set to “syslog”, log is sent to syslogd instead of being written

; in a local file.

; Note: the default prefix is /home/wangwei/php/var

; Default Value: log/php-fpm.log

error_log = /home/work/log/php-fpm.log.wf

修改之後,保存配置,然後重啟php-fpm就可以啦。

注意如果用相對路徑的話,的路徑的前綴是基於php安裝目錄的var目錄的。

thinkphp5 怎麼記錄詳細日誌

這樣試試呢,我看後盾網的老師是這麼講的,’log’ = [

// 日誌記錄方式,內置 file socket 支持擴展

‘type’ = ‘File’,

// 日誌保存目錄

‘path’ = LOG_PATH,

// 日誌記錄級別

‘level’ = [],//log 常規日誌,用於記錄日誌;error 錯誤,一般會導致程序的終止;notice 警告,程序可以運行但是還不夠完美的錯誤

// error和sql日誌單獨記錄

‘apart_level’ = [‘error’,’sql’],

//單個日誌文件的大小限制,超過後會自動記錄到第二個文件

‘file_size’ =2097152,

//日誌的時間格式,默認是` c `

‘time_format’ =’c’

]希望能幫到你(◉㉨◉)

php網站日誌怎麼記錄

php有自己的日誌機制的,去php.ini里配置一項error_log相關的配置項就可以了。

php實現日誌管理(記錄用戶操作)原理

把日誌需要保留的數據用json串或xml等數據結構的方式存儲起來,調用的時候直接解析這些數據結構即可。

按簡單的理解,給各模塊的關鍵步驟起個操作名字,記錄一下該操作名,時間,用戶,IP等就完了。

單入口模式,這樣只需要往index.php加入write_log功能就好了。

至於哪個字段,原值,新值,這個沒什麼好方法啊,可以引入插件機制,

開個類存儲插件方法,命名以module_task為準,比如以上的url就是article_update

那麼這個插件類就是

class plugin

{

public $extraLog;

function article_update($field,$old,$new)

{

self::$extraLog = array(‘字段’=$field,’原值’=$old,’新值’=$new);

}

}

這個方法在流程頁面進行數據庫操作的地方調用,index.php的write_log流程只讀plubin::$extraLog,循環然後和其它信息一起入庫或文件。

記錄PHP錯誤日誌 display_errors與log_errors的區別

display_errors

錯誤回顯,一般常用語開發模式,但是很多應用在正式環境中也忘記了關閉此選項。錯誤回顯可以暴露出非常多的敏感信息,為攻擊者下一步攻擊提供便利。推薦關閉此選項。

display_errors

=

On

開啟狀態下,若出現錯誤,則報錯,出現錯誤提示

dispaly_errors

=

Off

關閉狀態下,若出現錯誤,則提示:服務器錯誤。但是不會出現錯誤提示

log_errors

在正式環境下用這個就行了,把錯誤信息記錄在日誌里。正好可以關閉錯誤回顯。

對於PHP開發人員來說,一旦某個產品投入使用,那麼第一件事就是應該將display_errors選項關閉,以免因為這些錯誤所透露的路徑、數據庫連接、數據表等信息而遭到黑客攻擊。

某個產品投入使用後,難免會有錯誤信息,那麼如何記錄這些對開發人員非常有用的信息呢?

將PHP的log_errors開啟即可,默認是記錄到WEB服務器的日誌文件里,比如Apache的error.log文件。

當然也可以記錄錯誤日誌到指定的文件中。

複製代碼

代碼如下:

#

vim

/etc/php.inidisplay_errors

=

Off

log_errors

=

On

error_log

=

/var/log/php-error.log

另外也可以設定error_log

=

syslog,使這些錯誤信息記錄到操作系統的日誌里。

display_errors

=

Off

//display中文意思是顯示所以display_error=off的意思就是不顯示錯誤了!

error_reporting

設定錯誤訊息回報的等級

2047我記得應該是E_ALL。

php.ini

文件中有許多配置設置。您應當已經設置好自己的

php.ini

文件並把它放在合適的目錄中,就像在

Linux

上安裝

PHP

Apache

2

的文檔說明中所示的那樣(請參閱

參考資料)。在調試

PHP

應用程序時,應當知道兩個配置變量。下面是這兩個變量及其默認值:

display_errors

=

Off

//關閉所有錯誤信息,為ON時為顯示所有錯誤信息。

error_reporting

=

E_ALL

E_ALL能從不良編碼實踐到無害提示到出錯的所有信息。E_ALL

對於開發過程來說有點太細,因為它在屏幕上為一些小事(例如變量未初始化)也顯示提示,會搞糟瀏覽器的輸出

所以不建議使用2047,最好把默認值改為:error_reporting

=

E_ALL

~E_NOTICE

PHP.ini中display_errors

=

Off失效的解決

問題:

PHP設置文件php.ini中明明已經設置display_errors

=

Off,但是在運行過程中,網頁上還是會出現錯誤信息。

解決:

經查log_errors=

On,據官方的說法,當這個log_errors設置為On,那麼必須指定error_log文件,如果沒指定或者指定的文件沒有權限寫入,那麼照樣會輸出到正常的輸出渠道,那麼也就使得display_errors

這個指定的Off失效,錯誤信息還是打印了出來。於是將log_errors

=

Off,問題就解決了。

經常見到error_reporting(7)直意為:設定錯誤訊息回報的等級。

value

constant

1

E_ERROR

2

E_WARNING

4

E_PARSE

8

E_NOTICE

16

E_CORE_ERROR

32

E_CORE_WARNING

64

E_COMPILE_ERROR

128

E_COMPILE_WARNING

256

E_USER_ERROR

512

E_USER_WARNING

1024

E_USER_NOTICE

2047

E_ALL

2048

E_STRICT

然而7=1+2+4

就是出錯時顯示1

E_ERROR

2

E_WARNING

4

E_PARSE

複製代碼

代碼如下:

?php

//禁用錯誤報告

error_reporting(0);

//報告運行時錯誤

error_reporting(E_ERROR

|

E_WARNING

|

E_PARSE);

//報告所有錯誤

error_reporting(E_ALL);

?

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/254445.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-14 17:42
下一篇 2024-12-14 17:42

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • Ojlat:一款快速開發Web應用程序的框架

    Ojlat是一款用於快速開發Web應用程序的框架。它的主要特點是高效、易用、可擴展且功能齊全。通過Ojlat,開發人員可以輕鬆地構建出高質量的Web應用程序。本文將從多個方面對Oj…

    編程 2025-04-29
  • Zlios——一個多功能的開發框架

    你是否在開發過程中常常遇到同樣的問題,需要不斷去尋找解決方案?你是否想要一個多功能、易於使用的開發框架來解決這些問題?那麼,Zlios就是你需要的框架。 一、簡介 Zlios是一個…

    編程 2025-04-29
  • Cron執行日誌用法介紹

    本文將從多個方面對cron執行日誌進行詳細闡述,包括cron執行日誌的定義、cron執行日誌的產生原因、cron執行日誌的格式以及如何解讀cron執行日誌。 一、定義 Cron是一…

    編程 2025-04-29
  • agavi開發框架

    Agavi是一個基於MVC模式的Web應用程序開發框架,以REST和面向資源的設計為核心思想。本文章將從Agavi的概念、優點、使用方法和實例等方面進行詳細介紹。 一、概念 Aga…

    編程 2025-04-29
  • Hibernate日誌打印sql參數

    本文將從多個方面介紹如何在Hibernate中打印SQL參數。Hibernate作為一種ORM框架,可以通過打印SQL參數方便開發者調試和優化Hibernate應用。 一、通過配置…

    編程 2025-04-29
  • Python unittest框架用法介紹

    Python unittest框架是Python自帶的一種測試框架,可以用來編寫並運行測試用例。在本文中,我們將從以下幾個方面詳細介紹Python unittest框架的使用方法和…

    編程 2025-04-29
  • com.alipay.sofa.bolt框架

    com.alipay.sofa.bolt框架是一款高性能、輕量級、可擴展的RPC框架。其廣泛被應用於阿里集團內部服務以及阿里雲上的服務。該框架通過NIO支持高並發,同時還內置了多種…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • 使用Snare服務收集日誌:完整教程

    本教程將介紹如何使用Snare服務收集Windows服務器上的日誌,並將其發送到遠程服務器進行集中管理。 一、安裝和配置Snare 1、下載Snare安裝程序並安裝。 https:…

    編程 2025-04-29

發表回復

登錄後才能評論