Maison >développement back-end >tutoriel php >Qui peut expliquer la classe d'encapsulation pour le rapport d'erreurs implémentée en PHP ?

Qui peut expliquer la classe d'encapsulation pour le rapport d'erreurs implémentée en PHP ?

巴扎黑
巴扎黑original
2017-08-13 10:19:251210parcourir

Cet article présente principalement la classe d'encapsulation de gestion des erreurs implémentée par PHP et analyse le jugement des erreurs PHP, les invites et les compétences opérationnelles liées aux journaux sous la forme d'exemples spécifiques. Les amis dans le besoin peuvent s'y référer

Le. les exemples de cet article décrivent la classe d'encapsulation de gestion des erreurs implémentée par PHP. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

1 Créez le fichier MyErrorHandler.php

Le code est le suivant :


<?php
class MyErrorHandler {
  public $message;
  public $filename;
  public $line;
  public $vars = array();
  protected $_noticeLog = &#39;F:\root\noticeLog.log&#39;;
  public function __construct ($message,$filename,$line,$vars) {
    $this->message = $message;
    $this->filename = $filename;
    $this->line = $line;
    $this->vars = $vars;
  }
  public static function deal ($errno,$errmsg,$filename,$line,$vars) {
    $self = new self($errno,$errmsg,$filename,$line,$vars);
    switch ($errno) {
      case E_USER_ERROR:
        return $self->dealError();
        break;
      case E_USER_WARNING:
      case E_WARNING:
        return $self->dealWarning();
        break;
      case E_NOTICE:
      case E_USER_NOTICE:
        return $self->dealNotice();
      default:
        return false;
    }
  }
  /**
  * 致命的错误
  */
  public function dealError() {
    ob_start();
    debug_print_backtrace();
    $backtrace = ob_get_flush();
    $errorMsg = <<<EOF
出现了致命的错误,如下:
产生错误的文件:{$this->filename}
产生错误的信息:{$this->message}
产生错误的行号:{$this->line}
追踪信息{$backtrace}
EOF;
    error_log($errorMsg,1,&#39;279921301@qq.com&#39;,&#39;From:php[error错误日志]&#39;);
    exit(1);
  }
  /**
  * 警告的错误
  */
  public function dealWarning() {
    $errorMsg = <<<EOF
出现了警告的错误,如下:
产生警告的文件:{$this->filename}
产生警告的信息:{$this->message}
产生警告的行号:{$this->line}
EOF;
    return error_log($errorMsg,1,&#39;279921301@qq.com&#39;,&#39;From:php[error警告日志]&#39;);
  }
  /**
  * 通知的错误
  */
  public function dealNotice() {
    $datetime = date(&#39;Y-m-d H:i:s&#39;);
    $errorMsg = <<<EOF
出现了通知的错误,如下:
产生通知的文件:{$this->filename}
产生通知的信息:{$this->message}
产生通知的行号:{$this->line}
产生通知的时间:{$datetime}
EOF;
    return error_log($errorMsg,3,$this->_noticeLog);
  }
}

2. Code de test


<?php
include "MyErrorHandler.php";
//报告所有 PHP 错误
error_reporting(-1);
//不显示错误信息
ini_set(&#39;display_errors&#39;,0);
set_error_handler(array(&#39;MyErrorHandler&#39;,&#39;deal&#39;));
echo $test; //Notice错误
settype($var,&#39;test&#39;); //警告错误
test();

Remarque : L'envoi d'emails nécessite de configurer la fonction mail en local Vous pouvez vous référer à l'article précédent "PHP. pour configurer sendmail sous Windows et utiliser la fonction mail() Comment envoyer des emails".

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn