PHP框架中的日志系統(tǒng)
Aug 08, 2016 am 09:32 AM?1 set_exception_handler(callback $exception_handler); //異常捕獲自定義處理函數(shù)注冊(cè)?
?1 set_error_handler(callback $error_handler); //錯(cuò)誤捕獲自定義處理函數(shù)注冊(cè)?
?1 register_shutdown_function(callback $callback); //程序執(zhí)行時(shí)異常終止錯(cuò)誤捕獲處理函數(shù)注冊(cè)?
<span>1</span> <span>set_exception_handler</span>(<span>array</span>("Myexception","exceptionHandler"<span>)); </span><span>2</span> <span>set_error_handler</span>(<span>array</span>("Myexception","errorHandler"<span>)); </span><span>3</span> <span>register_shutdown_function</span>(<span>array</span>("Myexception","shutdownHandler"));
<span>109</span> <span>/*</span><span>* </span><span>110</span> <span> * Attach the file write to logging. Multiple writers are supported. </span><span>111</span> <span>*/</span> <span>112</span> Kohana::<span>$log</span>->attach(<span>new</span> Log_File(APPPATH.'logs'));
??? 這個(gè)就是添加一個(gè)日志記錄對(duì)象到日志對(duì)象中,注意橄欖色打底的倆個(gè),他們是不同的類庫(kù)實(shí)例,在kohana中,日志記錄對(duì)象分為兩部分,第一部分就是日志對(duì)象,用來維護(hù)一個(gè)日志記錄對(duì)象的列表,這個(gè)要怎么理解呢,其實(shí)就像一個(gè)容器,里面包含了一個(gè)或多個(gè)日志記錄對(duì)象(這個(gè)就是第二部分,這些日志記錄對(duì)象才是真正來記錄日志的),還有每個(gè)對(duì)象要記錄的錯(cuò)誤等級(jí)的數(shù)組,當(dāng)滿足錯(cuò)誤等級(jí)的時(shí)候才會(huì)去記錄,不滿足就會(huì)略掉。下面是我自己簡(jiǎn)化重命名后的日志記錄方式:
<span>1</span> self::<span>$log</span> = <span>Log</span>::<span>instance(); </span><span>2</span> self::<span>$log</span>->attach(<span>new</span> Logwriter("./data/debug"),<span>Log</span>::<span>DEBUG); </span><span>3</span> self::<span>$log</span>->attach(<span>new</span> Logwriter("./data/notice"),<span>Log</span>::NOTICE);
??? 我這里面為了更好地理解,將“容器”命名為L(zhǎng)og,記錄的實(shí)例命名為L(zhǎng)ogwriter,可以看到我在程序入口處很容易的添加了兩不同的日志種類,第一個(gè)是記錄所有錯(cuò)誤號(hào)比Log::DEBUG小的錯(cuò)誤(錯(cuò)誤級(jí)別比他高),并按規(guī)則記錄在文件夾./data/debug下面,第二個(gè)是記錄級(jí)別等于或高于Log::NOTICE的錯(cuò)誤,當(dāng)然了你還可以更詳細(xì)制定具體哪些錯(cuò)誤好,傳遞數(shù)組就行了,這個(gè)就是我感覺方便、快捷的地方,我們可以根據(jù)需求來添加錯(cuò)誤日志、分不同的日志目錄,下面看一幅圖也許會(huì)有助于理解:
????????????????????????????????????????????????????????????????????????????????????????????????????? log與logwriter的關(guān)系
??? 通過上面的圖你就會(huì)看到Log是一個(gè)容器,包含了具體的不同的logwriter對(duì)象,每個(gè)對(duì)象可能要記錄不同的信息,當(dāng)錯(cuò)誤信息要刷到文件中的時(shí)候,會(huì)運(yùn)行每一個(gè)Logwriter實(shí)例,看看自己是否要記錄errormessage中的錯(cuò)誤,errormessage中的level不包含在Logwriter內(nèi)時(shí)忽略。
??? 這本分和第一部分怎么合作的呢?其實(shí)很簡(jiǎn)單,當(dāng)exception捕獲的異常時(shí)會(huì)調(diào)用添加一條錯(cuò)誤信息(包括錯(cuò)誤位置、錯(cuò)誤代號(hào)、錯(cuò)誤信息等信息)到Log容器中的errormessage數(shù)組中,然后當(dāng)程序結(jié)束之后在將這些信息寫入文件,這里還要注意下,也許你在閱讀kohana代碼是發(fā)現(xiàn)沒有明顯的直接寫入到日志中去,這里面kohana優(yōu)化的比較好,因?yàn)閜hp的一次執(zhí)行可能出現(xiàn)多個(gè)錯(cuò)誤,如果來一個(gè)錯(cuò)誤你就去記錄一次這樣會(huì)在程序返回之前占用多余的io和時(shí)間,所以kohana的做法是默認(rèn)將所有的錯(cuò)誤、異常、日志存放在Log::$errormessage中,并在實(shí)例化的時(shí)候講Log中的writer操作注冊(cè)register_shutdown_function,這個(gè)函數(shù)的作用是在程序異常終止或者執(zhí)行完成之后執(zhí)行,前面第一部分也有使用到,這樣日志記錄就不會(huì)對(duì)本次php的執(zhí)行產(chǎn)生帶大的影響。
三、實(shí)例總結(jié)
??? 到這里你應(yīng)該已經(jīng)了解了日志系統(tǒng)的大概了,已經(jīng)可以自己編寫一個(gè)”日志系統(tǒng)”來使用了,下面看看我的”日志系統(tǒng)“的例子,這是github地址,里面有代碼和例子,需要的話可以看看。
https://github.com/AizuYan/phplog.git
本文版權(quán)歸作者(luluyrt@163.com)和博客園共有,未經(jīng)作者本人同意禁止任何形式的轉(zhuǎn)載,轉(zhuǎn)載文章之后必須在文章頁(yè)面明顯位置給出作者和原文連接,否則保留追究法律責(zé)任的權(quán)利。
以上就介紹了PHP框架中的日志系統(tǒng),包括了方面的內(nèi)容,希望對(duì)PHP教程有興趣的朋友有所幫助。

熱AI工具

Undress AI Tool
免費(fèi)脫衣服圖片

Undresser.AI Undress
人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover
用于從照片中去除衣服的在線人工智能工具。

Clothoff.io
AI脫衣機(jī)

Video Face Swap
使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費(fèi)的代碼編輯器

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

禪工作室 13.0.1
功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁(yè)開發(fā)工具

SublimeText3 Mac版
神級(jí)代碼編輯軟件(SublimeText3)

Windows11將清新優(yōu)雅的設(shè)計(jì)帶到了最前沿;現(xiàn)代界面允許您個(gè)性化和更改最精細(xì)的細(xì)節(jié),例如窗口邊框。在本指南中,我們將討論分步說明,以幫助您在Windows操作系統(tǒng)中創(chuàng)建反映您的風(fēng)格的環(huán)境。如何更改窗口邊框設(shè)置?按+打開“設(shè)置”應(yīng)用。WindowsI轉(zhuǎn)到個(gè)性化,然后單擊顏色設(shè)置。顏色更改窗口邊框設(shè)置窗口11“寬度=”643“高度=”500“>找到在標(biāo)題欄和窗口邊框上顯示強(qiáng)調(diào)色選項(xiàng),然后切換它旁邊的開關(guān)。若要在“開始”菜單和任務(wù)欄上顯示主題色,請(qǐng)打開“在開始”菜單和任務(wù)欄上顯示主題

“你的組織要求你更改PIN消息”將顯示在登錄屏幕上。當(dāng)在使用基于組織的帳戶設(shè)置的電腦上達(dá)到PIN過期限制時(shí),就會(huì)發(fā)生這種情況,在該電腦上,他們可以控制個(gè)人設(shè)備。但是,如果您使用個(gè)人帳戶設(shè)置了Windows,則理想情況下不應(yīng)顯示錯(cuò)誤消息。雖然情況并非總是如此。大多數(shù)遇到錯(cuò)誤的用戶使用個(gè)人帳戶報(bào)告。為什么我的組織要求我在Windows11上更改我的PIN?可能是您的帳戶與組織相關(guān)聯(lián),您的主要方法應(yīng)該是驗(yàn)證這一點(diǎn)。聯(lián)系域管理員會(huì)有所幫助!此外,配置錯(cuò)誤的本地策略設(shè)置或不正確的注冊(cè)表項(xiàng)也可能導(dǎo)致錯(cuò)誤。即

默認(rèn)情況下,Windows11上的標(biāo)題欄顏色取決于您選擇的深色/淺色主題。但是,您可以將其更改為所需的任何顏色。在本指南中,我們將討論三種方法的分步說明,以更改它并個(gè)性化您的桌面體驗(yàn),使其具有視覺吸引力。是否可以更改活動(dòng)和非活動(dòng)窗口的標(biāo)題欄顏色?是的,您可以使用“設(shè)置”應(yīng)用更改活動(dòng)窗口的標(biāo)題欄顏色,也可以使用注冊(cè)表編輯器更改非活動(dòng)窗口的標(biāo)題欄顏色。若要了解這些步驟,請(qǐng)轉(zhuǎn)到下一部分。如何在Windows11中更改標(biāo)題欄的顏色?1.使用“設(shè)置”應(yīng)用按+打開設(shè)置窗口。WindowsI前往“個(gè)性化”,然

任務(wù)欄縮略圖可能很有趣,但它們也可能分散注意力或煩人??紤]到您將鼠標(biāo)懸停在該區(qū)域的頻率,您可能無意中關(guān)閉了重要窗口幾次。另一個(gè)缺點(diǎn)是它使用更多的系統(tǒng)資源,因此,如果您一直在尋找一種提高資源效率的方法,我們將向您展示如何禁用它。不過,如果您的硬件規(guī)格可以處理它并且您喜歡預(yù)覽版,則可以啟用它。如何在Windows11中啟用任務(wù)欄縮略圖預(yù)覽?1.使用“設(shè)置”應(yīng)用點(diǎn)擊鍵并單擊設(shè)置。Windows單擊系統(tǒng),然后選擇關(guān)于。點(diǎn)擊高級(jí)系統(tǒng)設(shè)置。導(dǎo)航到“高級(jí)”選項(xiàng)卡,然后選擇“性能”下的“設(shè)置”。在“視覺效果”選

您是否在Windows安裝程序頁(yè)面上看到“出現(xiàn)問題”以及“OOBELANGUAGE”語句?Windows的安裝有時(shí)會(huì)因此類錯(cuò)誤而停止。OOBE表示開箱即用的體驗(yàn)。正如錯(cuò)誤提示所表示的那樣,這是與OOBE語言選擇相關(guān)的問題。沒有什么可擔(dān)心的,你可以通過OOBE屏幕本身的漂亮注冊(cè)表編輯來解決這個(gè)問題??焖傩迯?fù)–1.單擊OOBE應(yīng)用底部的“重試”按鈕。這將繼續(xù)進(jìn)行該過程,而不會(huì)再打嗝。2.使用電源按鈕強(qiáng)制關(guān)閉系統(tǒng)。系統(tǒng)重新啟動(dòng)后,OOBE應(yīng)繼續(xù)。3.斷開系統(tǒng)與互聯(lián)網(wǎng)的連接。在脫機(jī)模式下完成OOBE的所

屏幕亮度是使用現(xiàn)代計(jì)算設(shè)備不可或缺的一部分,尤其是當(dāng)您長(zhǎng)時(shí)間注視屏幕時(shí)。它可以幫助您減輕眼睛疲勞,提高易讀性,并輕松有效地查看內(nèi)容。但是,根據(jù)您的設(shè)置,有時(shí)很難管理亮度,尤其是在具有新UI更改的Windows11上。如果您在調(diào)整亮度時(shí)遇到問題,以下是在Windows11上管理亮度的所有方法。如何在Windows11上更改亮度[10種方式解釋]單顯示器用戶可以使用以下方法在Windows11上調(diào)整亮度。這包括使用單個(gè)顯示器的臺(tái)式機(jī)系統(tǒng)以及筆記本電腦。讓我們開始吧。方法1:使用操作中心操作中心是訪問

在Windows11上的顯示縮放方面,我們都有不同的偏好。有些人喜歡大圖標(biāo),有些人喜歡小圖標(biāo)。但是,我們都同意擁有正確的縮放比例很重要。字體縮放不良或圖像過度縮放可能是工作時(shí)真正的生產(chǎn)力殺手,因此您需要知道如何對(duì)其進(jìn)行自定義以充分利用系統(tǒng)功能。自定義縮放的優(yōu)點(diǎn):對(duì)于難以閱讀屏幕上的文本的人來說,這是一個(gè)有用的功能。它可以幫助您一次在屏幕上查看更多內(nèi)容。您可以創(chuàng)建僅適用于某些監(jiān)視器和應(yīng)用程序的自定義擴(kuò)展配置文件??梢詭椭岣叩投擞布男阅?。它使您可以更好地控制屏幕上的內(nèi)容。如何在Windows11

Windows上的激活過程有時(shí)會(huì)突然轉(zhuǎn)向顯示包含此錯(cuò)誤代碼0xc004f069的錯(cuò)誤消息。雖然激活過程已經(jīng)聯(lián)機(jī),但一些運(yùn)行WindowsServer的舊系統(tǒng)可能會(huì)遇到此問題。通過這些初步檢查,如果這些檢查不能幫助您激活系統(tǒng),請(qǐng)?zhí)D(zhuǎn)到主要解決方案以解決問題。解決方法–關(guān)閉錯(cuò)誤消息和激活窗口。然后,重新啟動(dòng)計(jì)算機(jī)。再次從頭開始重試Windows激活過程。修復(fù)1–從終端激活從cmd終端激活WindowsServerEdition系統(tǒng)。階段–1檢查Windows服務(wù)器版本您必須檢查您使用的是哪種類型的W
