用PHP即時捕捉PHP原始碼中的錯誤並發送email通知

来源:http://www.cnblogs.com/shouce/archive/2016/05/30/5541071.html
-Advertisement-
Play Games

開發PHP的朋友都知道,其實最擔心的就是程式中出現一些異常或錯誤,這些狀況如果輸出到用戶的螢幕會把用戶給嚇壞,甚至為此丟了工作,如果不輸出到螢幕就得想辦法記錄到日誌中,但是似乎不是每個人都有查看錯誤日誌的習慣,爲瞭解決這個尷尬的問題,所以我寫了這段代碼,其用意就是當我們寫的php程式出錯的時候把錯誤 ...


開發PHP的朋友都知道,其實最擔心的就是程式中出現一些異常或錯誤,這些狀況如果輸出到用戶的螢幕會把用戶給嚇壞,甚至為此丟了工作,如果不輸出到螢幕就得想辦法記錄到日誌中,但是似乎不是每個人都有查看錯誤日誌的習慣,爲瞭解決這個尷尬的問題,所以我寫了這段代碼,其用意就是當我們寫的php程式出錯的時候把錯誤內容捕捉出來然後發到我們的email內.
先看效果:

 

Define('SYS_DEBUG',false);
IF(SYS_DEBUG) {
ini_set('display_errors','on');
Error_reporting(E_ALL);//上線後使用該設定Error_reporting(E_ERROR | E_WARNING | E_PARSE);
}Else{
ini_set('display_errors','off');
Error_reporting(0);
}

//錯誤捕捉
Register_shutdown_function('Fun::Error');

Class Fun{

/**
通用出錯處理
參數:
要輸出的內容,是否終止執行程式
說明:
有傳值時該函式可以用來輸出自定義的錯誤內容
另外還可以配合Register_shutdown_function實現自動抓取錯誤內容,並將抓取的錯誤內容發送到Email內
Register_shutdown_function的機制是程式執行完畢或中途出錯時調用函數
如果是自動抓取錯誤時被調用,則會取得最後一次出錯的內容,如果發現沒有錯誤內容則跳出
返回:
內容會被直接輸出至螢幕或Email內
用法:
Fun::Error('錯誤內容');
Fun::Error('錯誤內容',False);
/**/
Public Static Function Error($M='',$E=True){
$ErrTpl='<head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"></head><body><table cellspacing="0" cellpadding="0" border="0"><tr><td style="padding:5px;background-color:#F57900;font-size:13px;border:1px solid #444;color:#222;">{$M}</td></tr></table>';

$M=Trim($M);
IF($M!='') {//手工調用
$M=' <b>註意:</b> '.$M;
Echo Strtr($ErrTpl,Array('{$M}'=>$M));unSet($ErrTpl);
IF($E===True) {Die();}
Return ;
}Else{//程式執行完畢自動抓取錯誤時調用
$M=error_get_last();//取得最後產生的錯誤
IF(!Is_array($M) Or Count($M)<4) {Unset($M);Return ;}
IF(!File_Exists($M['file'])) {Unset($M);Return ;}

//取得5行出錯關鍵代碼,如果取不到內容,說明出錯檔案不存在
$E=Array_slice(File($M['file']),($M['line']-4),5);
IF(!Is_array($E)) {Unset($M,$E);Return ;}

$E['M']='';
For($i=0;$i<5;$i++) {
$E[$i]=isSet($E[$i]) ? $E[$i] : '';
$E['M'].='&nbsp;&nbsp;';
$E['M'].=($i==3) ? '<b>'.(($M['line']-3)+($i+1)).'</b>' : (($M['line']-3)+($i+1));
$E['M'].=': '.Htmlspecialchars($E[$i],ENT_QUOTES,'UTF-8').'<br>';
}
$E=&$E['M'];

$M='<b>自動捕捉到有錯誤產生!</b><br><br><b>錯誤描述:</b><br>&nbsp;&nbsp;<b>'.$M['file'].'</b>的第<b>'.$M['line'].'</b>行出現了類型為<b>'.$M['type'].'</b>的錯誤:<br>&nbsp;&nbsp;'.$M['message'].'<br><br><b>關鍵代碼:</b><br>'.$E.'<br>'.self::now('Y-m-d H:i:s',time()).'<br>';

$M=Strtr($ErrTpl,Array('{$M}'=>$M));unSet($ErrTpl);

$G=seft::getG('SYS','config');
IF(!self::Mail2($G['Spe'],'警告: '.$G['Tit'].' 出現 PHP 程式錯誤!',$M) And SYS_DEBUG===True){
throw new Exception('警告: '.$G['Tit'].' 出現 PHP 程式錯誤!<br><br>'.$M);
}
IF(SYS_DEBUG) {Echo $M;}
unSet($E,$M,$G);
Die();
}
}
/**
發送電郵
參數:
收件人,郵件標題(不可有換行符),郵件內容(行與行之間必須用\n分隔,每行不可超過70個字元)
說明:
調用PHP內置函式Mail發送電郵
返回:
返回布爾值
用法:
$IsSend=Fun::Mail2($email,$tit,$msg);
/**/
Public Static Function Mail2($to,$tit,$msg) {
IF(Filter_var($to,FILTER_VALIDATE_EMAIL)==''){
throw new Exception('電郵地址錯誤!');
}

$tit='=?UTF-8?B?'.Base64_Encode($tit).'?=';
$msg = str_replace("\n.","\n..",$msg);     //Windows如果在一行開頭髮現一個句號則會被刪掉,要避免此問題將單個句號替換成兩個句號

Return Mail($to,$tit,$msg,'From:'.seft::getG('config/SYS/Mal')."\n".'Content-Type:text/html;charset=utf-8');
}


}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 全文包括如下三部分內容: 方式一、發佈網站至預設的IIS路徑下 方式二、發佈網站至指定的IIS路徑下 註:發佈過程中可能出現的錯誤信息及解決方法 方式一、發佈網站至預設的IIS路徑下 1)發佈環境:Windows 7 旗艦版 + IIS 7.5 + VS2010 + ASP.Net WebForm ...
  • 在.NET發展史中,2.0是具有里程碑意義的一個版本。從這個版本,.NET青出於藍(Java),而勝於藍。在.NET 2.0帶來的諸多新特性中,我認為泛型是最重要,沒有之一。 雖然泛型出現已有多年,連Java都早已借鑒引入了泛型(雖然是語法糖),可是用泛型的編程思維方式並沒有得到相應的普及。一方面是 ...
  • 我們首先從創建ASP.NET MVC項目開始。打開Visual Studio,在文件菜單中選擇新建-> 項目,然後在模板中選擇Web,接著選擇ASP.Net Web應用程式,更改項目名稱,點擊確定,接著選擇ASP.NET 4.5.2模板為Empty,勾選核心引用MVC,確定,然後一個ASP.NET ...
  • 在上一篇文章中,我們已經學到了很基本的MEF概念和使用方法。 但我們導出的是一個object類型的實例,只能用來tostring,沒有引用部件類庫,也不能用裡面的成員方法。 本篇,我們逐漸往簡單的文件管理器的目標靠攏。 新建類庫IPart,添加一個介面IFileHandler.cs Parts類庫和 ...
  • 上一篇我們已經獲得了制定類型的實例,但我們還無法對其進行有效的控制。 我們用ExportMetadata屬性可以對具體的某個實例做標記,相當於命名。這麼理解不知道對否。 在IPart項目中添加一個介面IPatMetadata 在導出的地方添加具體的導出元數據ExportMetadata,以txtFi ...
  • 1、創建線程的一種簡單方法是定義一個委托,並非同步調用它。 增加代碼中第17行的Sleep方法的參數值,輸出的星號的個數會減少,反之會增加。 運行結果: 2、IAsyncResult有一個名字叫AsyncWaitHandle的屬性,該屬性的類型是WaitHandle類。該類的WaitOne方法會“將一 ...
  • 分別向Set集合以及List集合中添加“A”,“a”,“c”,“C”,“a”5個元素,觀察重覆值“a”能否在List集合以及Set集合中成功添加。 運行: ...
  • 使用源文件 現在讓我們重新開始編程。當你學習一種新的編程語言的時候,你編寫運行的第一個程式通常都是“Hello World”程式,這已經成為一種傳統了。在你運行“Hello World”程式的時候,它所做的事只是說聲:“Hello World”。正如提出“Hello World”程式的Simon C ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...