簡單一點
  • 首頁
  • 技術教程
  • 網絡資源
  • 軟件工具
  • 隨心所欲
  • 編程筆記
  • 問答社區
  • 單詞庫
登錄 註冊
投稿
  1. 簡單一點首頁
  2. 編程

開啟php的錯誤log日誌,php login

E2Z6D • 2024-10-03 23:24 • 編程

本文目錄一覽:

  • 1、記錄PHP錯誤日誌 display_errors與log_errors的區別
  • 2、PHP中error_log()函數的使用方法
  • 3、怎麼讓php打印錯誤日誌?
  • 4、nginx php fpm 如何顯示錯誤日誌
  • 5、如何開啟PHP日誌功能?
  • 6、為什麼一開啟php.ini里的error_log,apache就啟動不了??

記錄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);

?

PHP中error_log()函數的使用方法

本文實例講述了PHP中error_log()函數的使用方法。分享給大家供大家參考。具體分析如下:

今天遇到一個問題需要調試,但是只能通過日誌打印調試,就用到了error_log這個函數

需要打印的是一台服務器發送到我們服務器的post數據

代碼如下:(key和value都打印了)

複製代碼

代碼如下:if(!empty($_POST)

){

while

(list($key,

$val)

=

each($_POST))

{

@error_log(“$key

=

$val”,

3,’/tmp/test_post_allstarpay.log’

);

}

}

error_log有四個參數

,主要是前3個,第一個是log日誌寫入內容,第二個是日誌存入方式3表示存入指定位置,第三個是存入位置

服務器用的是centos

,tmp有讀寫權限

所以就寫入tmp內了

error_log會自動生成相應的log文件,不需要手動創建!

希望本文所述對大家的php程序設計有所幫助。

怎麼讓php打印錯誤日誌?

(1)使用echo ,簡單輸出

(2)使用print_r(),可以有規則的打印複雜結構

(3)var_dump遞歸輸出某種結構體

(4)print(),簡單打印

可以將你要輸出的錯誤內容放到上述語句或函數內進行打印輸出;也可以寫入某個文件,作為你的Log日誌:file_put_contents(‘/test1.txt’,$value[‘value’],FILE_APPEND)等這類文件函數

以上是我自己工作中總結的PHP調試方法,挺好用的。

nginx php fpm 如何顯示錯誤日誌

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

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

; 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之前的;去掉,然後修改為:

; 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目錄的。

如何開啟PHP日誌功能?

在php編程中,對於一些訪問沒有明顯錯誤提示的php頁面,可以通過error_log來做進一步的判定。

但出於種種原因,有些服務器並沒有開啟PHP的error_log功能。

測試或其它需要時,可以打開一下,方法如下。

編輯php.ini,將log_errors設置為on:

log_errors = On

然後,重啟apache即可。

如成功開啟,就可以跟蹤到對應的錯誤提示:

[Mon Sep 24 16:57:01 2012] [error] [client 218.5.80.210] PHP Warning: fsockopen() has been disabled for security reasons in /home/bccgi-bin/fsockopen.php on line 2

[Mon Sep 24 16:57:02 2012] [error] [client 218.5.80.210] PHP Warning: fsockopen() has been disabled for security reasons in /home/bccgi-bin/fsockopen.php on line 2

[Mon Sep 24 16:57:03 2012] [error] [client 218.5.80.210] PHP Warning: fsockopen() has been disabled for security reasons in /home/bccgi-bin/fsockopen.php on line 2

[Mon Sep 24 16:57:04 2012] [error] [client 218.5.80.210] PHP Warning: fsockopen() has been disabled for security reasons in /home/bccgi-bin/fsockopen.php on line

另外,注意在Windows環境下,除了將log_errors設置為on外,還需要定義error_log的路徑及文件名:

error_log = d:/temp/error.log

(此目錄需要授予php標識用戶的修改權限,否則日誌文件無法生成)

IIS沒有error_log的概念,所以需要另外定義。

為什麼一開啟php.ini里的error_log,apache就啟動不了??

檢查一下error_log的目錄或error_log文件有沒有apache用戶的可寫權限

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

loginphp日誌錯誤
贊 (0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
E2Z6D的頭像E2Z6D
0 0
生成海報
jsp網頁編程內容總結ppt,jsp網站開發實訓總結
上一篇 2024-10-03 23:24
java用什麼編譯器來寫程序,java編譯器用什麼寫的
下一篇 2024-10-03 23:24

相關推薦

  • PHP和Python哪個好找工作?

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

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

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

    JQUMY的頭像 JQUMY
    編程 2025-04-29
  • Hibernate日誌打印sql參數

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

    ZPNAH的頭像 ZPNAH
    編程 2025-04-29
  • PHP怎麼接幣

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

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

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

    IRPJL的頭像 IRPJL
    編程 2025-04-29
  • Python載入Cookie錯誤解決方法用法介紹

    本文將從多個方面詳細闡述Python載入Cookie錯誤的解決方法,希望能對讀者有所幫助。 一、Cookie錯誤常見原因 1、Cookie過期:當Cookie過期時,載入Cooki…

    KNSLE的頭像 KNSLE
    編程 2025-04-29
  • Log4j日誌打印到Systemout.log

    Log4j是Apache的一個強大的日誌組件,可以幫助開發者更好地管理日誌。在Java應用程序中,很多開發者都會選擇使用Log4j來實現日誌輸出。本文將介紹如何使用Log4j將日誌…

    YXLCJ的頭像 YXLCJ
    編程 2025-04-28
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    ATMUX的頭像 ATMUX
    編程 2025-04-28
  • Treck TCP/IP Stack 輸入驗證錯誤漏洞CVE-2020-11901解析

    本文將對Treck TCP/IP Stack 輸入驗證錯誤漏洞CVE-2020-11901進行詳細解析,並提供相關代碼示例。 一、漏洞背景 Treck TCP/IP Stack是一…

    NDNEA的頭像 NDNEA
    編程 2025-04-27
  • electron-egg打包後請求地址錯誤解決方法用法介紹

    本文將從多個方面對electron-egg打包後請求地址錯誤進行詳細闡述,並給出解決方法。 一、electron-egg打包後請求地址錯誤的表現 在使用 electron-egg …

    QKWAR的頭像 QKWAR
    編程 2025-04-27

發表回復

請登錄後評論...
登錄後才能評論
E2Z6D
E2Z6D的頭像
E2Z6D

這個人很懶,什麼都沒有留下~

1 文章
0 評論
0 粉絲

最近文章

  • 開啟php的錯誤log日誌,php login

繁體

不轉換 繁體中文 港澳繁體 台灣正體

文章目錄Toggle Table of ContentToggle

  • 本文目錄一覽:
  • 記錄PHP錯誤日誌 display_errors與log_errors的區別
  • PHP中error_log()函數的使用方法
  • 怎麼讓php打印錯誤日誌?
  • nginx php fpm 如何顯示錯誤日誌
  • 如何開啟PHP日誌功能?
  • 為什麼一開啟php.ini里的error_log,apache就啟動不了??

可能喜歡

  • 超過 3 萬個公開可用的 IPTV 頻道列表

    超過 3 萬個公開可用的 IPTV 頻道列表

  • 剪映識別的字幕文件在哪裡?

    剪映識別的字幕文件在哪裡?

  • 一款去中心化的 YouTube 彈幕插件

    一款去中心化的 YouTube 彈幕插件

  • 提升敲命令體驗的 Raycast 插件:快命令

    提升敲命令體驗的 Raycast 插件:快命令

  • 位元組跳動旗下豆包AI編程助手MarsCode拉新活動:京東E卡

    位元組跳動旗下豆包AI編程助手MarsCode拉新活動:京東E卡

  • 可靈AI悄然上線獨立APP!

    可靈AI悄然上線獨立APP!

  • 「百度快速抓取2024年最新申請方法」使用說明與權益獲取

    「百度快速抓取2024年最新申請方法」使用說明與權益獲取

  • 百度站長平台「快速收錄」4月26日下線

    百度站長平台「快速收錄」4月26日下線

  • 騰訊雲遨馳終端(OrcaTerm)輕量(2折)和CVM(5折)服務器續費券

    騰訊雲遨馳終端(OrcaTerm)輕量(2折)和CVM(5折)服務器續費券

  • 4核8G雲服務器適合裝寶塔MySQL 那個版本

    4核8G雲服務器適合裝寶塔MySQL 那個版本

  • Base64編碼解碼
  • 剪映字幕導出工具
  • 導入剪映字幕工具

Copyright © 2024 簡單一點 版權所有 滇ICP備2024022404號-1 Powered by 506064.Com