当前位置:Gxlcms > PHP教程 > php实现的错误处理封装类实例

php实现的错误处理封装类实例

时间:2021-07-01 10:21:17 帮助过:55人阅读

本文实例讲述了php实现的错误处理封装类。分享给大家供大家参考,具体如下:

1、创建MyErrorHandler.php文件

代码如下:

  1. <?php
  2. class MyErrorHandler {
  3. public $message;
  4. public $filename;
  5. public $line;
  6. public $vars = array();
  7. protected $_noticeLog = 'F:\root\noticeLog.log';
  8. public function __construct ($message,$filename,$line,$vars) {
  9. $this->message = $message;
  10. $this->filename = $filename;
  11. $this->line = $line;
  12. $this->vars = $vars;
  13. }
  14. public static function deal ($errno,$errmsg,$filename,$line,$vars) {
  15. $self = new self($errno,$errmsg,$filename,$line,$vars);
  16. switch ($errno) {
  17. case E_USER_ERROR:
  18. return $self->dealError();
  19. break;
  20. case E_USER_WARNING:
  21. case E_WARNING:
  22. return $self->dealWarning();
  23. break;
  24. case E_NOTICE:
  25. case E_USER_NOTICE:
  26. return $self->dealNotice();
  27. default:
  28. return false;
  29. }
  30. }
  31. /**
  32. * 致命的错误
  33. */
  34. public function dealError() {
  35. ob_start();
  36. debug_print_backtrace();
  37. $backtrace = ob_get_flush();
  38. $errorMsg = <<<EOF
  39. 出现了致命的错误,如下:
  40. 产生错误的文件:{$this->filename}
  41. 产生错误的信息:{$this->message}
  42. 产生错误的行号:{$this->line}
  43. 追踪信息{$backtrace}
  44. EOF;
  45. error_log($errorMsg,1,'279921301@qq.com','From:php[error错误日志]');
  46. exit(1);
  47. }
  48. /**
  49. * 警告的错误
  50. */
  51. public function dealWarning() {
  52. $errorMsg = <<<EOF
  53. 出现了警告的错误,如下:
  54. 产生警告的文件:{$this->filename}
  55. 产生警告的信息:{$this->message}
  56. 产生警告的行号:{$this->line}
  57. EOF;
  58. return error_log($errorMsg,1,'279921301@qq.com','From:php[error警告日志]');
  59. }
  60. /**
  61. * 通知的错误
  62. */
  63. public function dealNotice() {
  64. $datetime = date('Y-m-d H:i:s');
  65. $errorMsg = <<<EOF
  66. 出现了通知的错误,如下:
  67. 产生通知的文件:{$this->filename}
  68. 产生通知的信息:{$this->message}
  69. 产生通知的行号:{$this->line}
  70. 产生通知的时间:{$datetime}
  71. EOF;
  72. return error_log($errorMsg,3,$this->_noticeLog);
  73. }
  74. }

2、测试代码

  1. <?php
  2. include "MyErrorHandler.php";
  3. //报告所有 PHP 错误
  4. error_reporting(-1);
  5. //不显示错误信息
  6. ini_set('display_errors',0);
  7. set_error_handler(array('MyErrorHandler','deal'));
  8. echo $test; //Notice错误
  9. settype($var,'test'); //警告错误
  10. test();

注意:发送邮件需要在本地配置mail函数,可以参考前文《PHP实现在windows下配置sendmail并通过mail()函数发送邮件的方法》。

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP错误与异常处理方法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP运算与运算符用法总结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家PHP程序设计有所帮助。

人气教程排行