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

開發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‘);
}

}
时间: 2024-12-29 15:49:09

用PHP即時捕捉PHP原始碼中的錯誤并發送email通知的相关文章

Python編碼格式錯誤解決方案及案例

Python格式錯誤解決方案及案例 這幾天在玩爬蟲,在解析和提取内容時經常出現由於内容格式問題導致出錯,為防止以後出錯,整下一下,以下是這幾天的總結: 1. 特殊符號或表情符號等 背景:爬取一個烹飪教學網站,在用BeautifulSoup解析網頁時報錯: UnicodeEncodeError: 'UCS-2' codec can't encode character '\U0001f44d' in position 0: Non-BMP character not supported in Tk

JavaScript基础 substr(startIndex, length) 在原始字符串中,截取并返回一个子字符串

镇场诗: 清心感悟智慧语,不着世间名与利.学水处下纳百川,舍尽贡高我慢意. 学有小成返哺根,愿铸一良心博客.诚心于此写经验,愿见文者得启发.------------------------------------------ code: 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=ut

JAVA----编程列出一个字符串的全字符组合情况,原始字符串中没有重复字符

package com.pb.demo.packclass.demo1; import java.util.HashSet; /** * 编程列出一个字符串的全字符组合情况,原始字符串中没有重复字符 例如: 原始字符串是"abc",打印得到下列所有组合情况 "a" "b" "c" "ab" "bc" "ca" "ba" "cb"

JavaScript基础 indexOf() 返回一个子字符串在原始字符串中的索引 从左往右查找

镇场诗: 清心感悟智慧语,不着世间名与利.学水处下纳百川,舍尽贡高我慢意. 学有小成返哺根,愿铸一良心博客.诚心于此写经验,愿见文者得启发.------------------------------------------ ex1: code: 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; chars

Oracle定時email通知

small_program_task 這張表的資料是待發送的email通知,再次之前已經有一個job會定時掃描固定時間內未接收到小程式回報狀態將其寫入到該表,send_flag為N,表示為寄過通知.email_notice_expired這個procedure負責寄出通信,簡單的HTML也直接寫在procedure裡面. /*EMAIL通知procedure email_notice_expired scan small_program_task表,將send_flag標記為N的寄出去. wri

[個人紀錄] WindowsLiveWriter 插入代碼跳出錯誤

跳出找不到設定檔Can't load configruaration fromC:\Users\-\AppData\Roaming\Windows Live Writer\WindowsLiveWriter.SourceCode.config 只要繼續點確定,一樣可以進入插入代碼的視窗中 再點選Option選擇你的設定,再點OK(直接點也可以), 下次再打開plugin就不會再跳錯誤了

捕捉WPF应用程序中XAML代码解析异常

原文:捕捉WPF应用程序中XAML代码解析异常 由于WPF应用程序中XAML代码在很多时候是运行时加载处理的.比如DynamicResource,但是在编译或者运行的过程中,编写的XAML代码很可能有错误,此时XAML代码解析器通常会抛出称为XamlParseException的异常.但是抛出的XamlParseException异常提供的信息非常简单,或者是很不准确.此时我们关于通过对变通的方法来获取更多的异常信息: 我们知道,WPF应用程序中的XAML代码是在InitializeCompon

python常用模块email----从原始邮件中提取邮件头信息

email.parser.Parser()的parsestr()和parse()方法都可以用来从原始邮件文件中提取邮件头信息.这两个方法的区别就parsestr处理的是字符串对象,parse处理的是文件对象.   让我们通过两个例子来了解这两个方法的使用.先来看一封邮件的原始信息的一部分: cat /tmp/email_test1.txt date: Wed, 16 Nov 2016 16:04:44 +0800 From: 3456789 <[email protected]> To: 12

JavaScript基础 lastIndexOf 从右往左查找 返回一个子字符串在原始字符串中的索引

镇场诗: 清心感悟智慧语,不着世间名与利.学水处下纳百川,舍尽贡高我慢意. 学有小成返哺根,愿铸一良心博客.诚心于此写经验,愿见文者得启发.------------------------------------------ code: 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=ut