error_reporting在php程式設計中的使用頻度,想必大家是非常清楚的了,本文介紹error_reporting的用法,供大家學習參考。 如果參數 level 未指定,則目前報錯等級將會傳回。以下幾項是 level 可能的值: 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 E_NOTICE 表示一般情形不記錄,只有程式有錯誤情形時才用到,例如企圖存取一個不存在的變數,或是呼叫 stat() 函數檢視不存在的檔案。 E_WARNING 通常都會顯示出來,但不會中斷程式的執行。這對調試很有效。例如:用有問題的常規表示法呼叫 ereg()。 E_ERROR 通常會顯示出來,也會中斷程式執行。意即用這個遮罩無法追查到記憶體配置或其它的錯誤。 E_PARSE 從語法中剖析錯誤。 E_CORE_ERROR 類似 E_ERROR,但不包含 PHP 核心造成的錯誤。 E_CORE_WARNING 類似 E_WARNING,但不包含 PHP 核心錯誤警告。 PHP 的錯誤回報 php.ini 檔案中有許多配置設定。您應該已經設定好自己的 php.ini 檔案並將它放在適當的目錄中,就像在 Linux 上安裝 PHP 和 Apache 2 的文件說明中所示的那樣。在偵錯 PHP 應用程式時,應知道兩個配置變數。以下是這兩個變數及其預設值: display_errors = Off error_reporting = E_ALL 透過在 php.ini 檔案中搜尋它們,可以發現這兩個變數目前的預設值。 display_errors 變數的目的很明顯 —— 它告訴 PHP 是否顯示錯誤。預設值是 Off。但是,要讓開發過程更加輕鬆,請把這個值設為 On: display_errors = On error_reporting 變數的預設值是 E_ALL。這個設定會顯示從不良編碼實踐到無害提示到出錯的所有資訊。 E_ALL 對於開發過程來說有點太細,因為它在螢幕上也會為一些小事(例如變數未初始化)顯示提示,會搞糟瀏覽器的輸出。我只想看到錯誤和不良編碼實踐,但是不想看到 無害的提示。所以,請用以下值來取代 error_reporting 的預設值: error_reporting = E_ALL & ~E_NOTICE 重新啟動 Apache,就全部設定好了。接下來,將學習如何在 Apache 上做同樣的事情。 伺服器上的錯誤報告依賴 Apache 正在做的工作,在 PHP 中開啟錯誤報告可能沒辦法工作,因為電腦上可能有多個 PHP 版本。有時很難區分 Apache 正在使用哪個 PHP 版本,因為 Apache 只能查看一個 php.ini 檔案。不知道 Apache 正在使用哪個 php.ini 檔案配置自己是一個安全性問題。但是,有一種方法可以在 Apache 中配置 PHP 變量,從而保證設定了正確的出錯等級。 而且,最好知道如何在伺服器端設定這些配置變量,以否決或搶佔 php.ini 文件,從而提供更高層級的安全性。 在設定 Apache 時,應該已經接觸過 /conf/httpd.conf 中 http.conf 檔案中的基本設定。 要做在 php.ini 檔案中已經做過的事,請把下列各行加入到 httpd.conf,覆蓋任何 php.ini 檔案: php_flag display_errors on php_value error_reporting 2039 這會覆蓋在 php.ini 檔案中已經設定為 display_errors 設定的標誌,以及 error_reporting 的值。值 2039 代表 E_ALL & ~E_NOTICE。如果願意採用 E_ALL,請把值設為 2047。同樣,還是要重啟 Apache。 接下來,要在伺服器上測試錯誤報告。 關於error_reporting()這個函數,它是可以屏蔽到一些錯誤訊息,但是PHP 核心造成的錯誤,是無法屏蔽的,因為PHP 核心造成的錯誤會直接導致PHP檔案編譯失敗,因為書寫格式沒有按照PHP的編碼規則寫而造成的錯誤,是無法屏蔽的。
常見的如下:
|

tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考慮使用AttActAcks.s.s.4)

會話再生是指在用戶進行敏感操作時生成新會話ID並使舊ID失效,以防會話固定攻擊。實現步驟包括:1.檢測敏感操作,2.生成新會話ID,3.銷毀舊會話ID,4.更新用戶端會話信息。

PHP会话对应用性能有显著影响。优化方法包括:1.使用数据库存储会话数据,提升响应速度;2.减少会话数据使用,只存储必要信息;3.采用非阻塞会话处理器,提高并发能力;4.调整会话过期时间,平衡用户体验和服务器负担;5.使用持久会话,减少数据读写次数。

PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3漢化版
中文版,非常好用

Dreamweaver Mac版
視覺化網頁開發工具