Table of Contents
$title Error
Home php教程 php手册 PHP系统异常处理类程序

PHP系统异常处理类程序

May 25, 2016 pm 04:47 PM
catch explode fopen foreach substr

以前我们用过的异常处理函数都是单个的,下面我找到一个非常的不错的异常处理类系统,不但可以控制错误还能给出好的界面哦。

<?php
// 自定义异常函数
set_exception_handler(&#39;handle_exception&#39;);
// 自定义错误函数
set_error_handler(&#39;handle_error&#39;);
/**
 * 异常处理
 *
 * @param mixed $exception 异常对象
 * @author www.phprm.com
 */
function handle_exception($exception) {
    Error::exceptionError($exception);
}
/**
 * 错误处理
 *
 * @param string $errNo 错误代码
 * @param string $errStr 错误信息
 * @param string $errFile 出错文件
 * @param string $errLine 出错行
 * @author www.phprm.com
 */
function handle_error($errNo, $errStr, $errFile, $errLine) {
    if ($errNo) {
        Error::systemError($errStr, false, true, false);
    }
}
/**
 * 系统错误处理
 *
 * @author http://www.phprm.com
 */
class Error {
    public static function systemError($message, $show = true, $save = true, $halt = true) {
        list($showTrace, $logTrace) = self::debugBacktrace();
        if ($save) {
            $messageSave = &#39;<b>&#39; . $message . &#39;</b><br /><b>PHP:</b>&#39; . $logTrace;
            self::writeErrorLog($messageSave);
        }
        if ($show) {
            self::showError(&#39;system&#39;, "<li>$message</li>", $showTrace, 0);
        }
        if ($halt) {
            exit();
        } else {
            return $message;
        }
    }
    /**
     * 代码执行过程回溯信息
     *
     * @static
     * @access public
     */
    public static function debugBacktrace() {
        $skipFunc[] = &#39;Error->debugBacktrace&#39;;
        $show = $log = &#39;&#39;;
        $debugBacktrace = debug_backtrace();
        ksort($debugBacktrace);
        foreach ($debugBacktrace as $k => $error) {
            if (!isset($error[&#39;file&#39;])) {
                // 利用反射API来获取方法/函数所在的文件和行数
                try {
                    if (isset($error[&#39;class&#39;])) {
                        $reflection = new ReflectionMethod($error[&#39;class&#39;], $error[&#39;function&#39;]);
                    } else {
                        $reflection = new ReflectionFunction($error[&#39;function&#39;]);
                    }
                    $error[&#39;file&#39;] = $reflection->getFileName();
                    $error[&#39;line&#39;] = $reflection->getStartLine();
                }
                catch(Exception $e) {
                    continue;
                }
            }
            $file = str_replace(SITE_PATH, &#39;&#39;, $error[&#39;file&#39;]);
            $func = isset($error[&#39;class&#39;]) ? $error[&#39;class&#39;] : &#39;&#39;;
            $func.= isset($error[&#39;type&#39;]) ? $error[&#39;type&#39;] : &#39;&#39;;
            $func.= isset($error[&#39;function&#39;]) ? $error[&#39;function&#39;] : &#39;&#39;;
            if (in_array($func, $skipFunc)) {
                break;
            }
            $error[&#39;line&#39;] = sprintf(&#39;%04d&#39;, $error[&#39;line&#39;]);
            $show.= &#39;<li>[Line: &#39; . $error[&#39;line&#39;] . &#39;]&#39; . $file . &#39;(&#39; . $func . &#39;)</li>&#39;;
            $log.= !empty($log) ? &#39; -> &#39; : &#39;&#39;;
            $log.= $file . &#39;:&#39; . $error[&#39;line&#39;];
        }
        return array(
            $show,
            $log
        );
    }
    /**
     * 异常处理
     *
     * @static
     * @access public
     * @param mixed $exception
     */
    public static function exceptionError($exception) {
        if ($exception instanceof DbException) {
            $type = &#39;db&#39;;
        } else {
            $type = &#39;system&#39;;
        }
        if ($type == &#39;db&#39;) {
            $errorMsg = &#39;(&#39; . $exception->getCode() . &#39;) &#39;;
            $errorMsg.= self::sqlClear($exception->getMessage() , $exception->getDbConfig());
            if ($exception->getSql()) {
                $errorMsg.= &#39;<div class="sql">&#39;;
                $errorMsg.= self::sqlClear($exception->getSql() , $exception->getDbConfig());
                $errorMsg.= &#39;</div>&#39;;
            }
        } else {
            $errorMsg = $exception->getMessage();
        }
        $trace = $exception->getTrace();
        krsort($trace);
        $trace[] = array(
            &#39;file&#39; => $exception->getFile() ,
            &#39;line&#39; => $exception->getLine() ,
            &#39;function&#39; => &#39;break&#39;
        );
        $phpMsg = array();
        foreach ($trace as $error) {
            if (!empty($error[&#39;function&#39;])) {
                $fun = &#39;&#39;;
                if (!empty($error[&#39;class&#39;])) {
                    $fun.= $error[&#39;class&#39;] . $error[&#39;type&#39;];
                }
                $fun.= $error[&#39;function&#39;] . &#39;(&#39;;
                if (!empty($error[&#39;args&#39;])) {
                    $mark = &#39;&#39;;
                    foreach ($error[&#39;args&#39;] as $arg) {
                        $fun.= $mark;
                        if (is_array($arg)) {
                            $fun.= &#39;Array&#39;;
                        } elseif (is_bool($arg)) {
                            $fun.= $arg ? &#39;true&#39; : &#39;false&#39;;
                        } elseif (is_int($arg)) {
                            $fun.= (defined(&#39;SITE_DEBUG&#39;) && SITE_DEBUG) ? $arg : &#39;%d&#39;;
                        } elseif (is_float($arg)) {
                            $fun.= (defined(&#39;SITE_DEBUG&#39;) && SITE_DEBUG) ? $arg : &#39;%f&#39;;
                        } else {
                            $fun.= (defined(&#39;SITE_DEBUG&#39;) && SITE_DEBUG) ? &#39;&#39;&#39; . htmlspecialchars(substr(self::clear($arg), 0, 10)) . (strlen($arg) > 10 ? &#39; . . . &#39; : &#39;&#39;) . &#39;&#39;&#39; : &#39;%s&#39;;
                        }
                        $mark = &#39;, &#39;;
                    }
                }
                $fun.= &#39;)&#39;;
                $error[&#39;function&#39;] = $fun;
            }
            if (!isset($error[&#39;line&#39;])) {
                continue;
            }
            $phpMsg[] = array(
                &#39;file&#39; => str_replace(array(
                    SITE_PATH,
                    &#39;&#39;
                ) , array(
                    &#39;&#39;,
                    &#39;/&#39;
                ) , $error[&#39;file&#39;]) ,
                &#39;line&#39; => $error[&#39;line&#39;],
                &#39;function&#39; => $error[&#39;function&#39;]
            );
        }
        self::showError($type, $errorMsg, $phpMsg);
        exit();
    }
    /**
     * 记录错误日志
     *
     * @static
     * @access public
     * @param string $message
     */
    public static function writeErrorLog($message) {
        return false; // 暂时不写入 http://www.phprm.com
        $message = self::clear($message);
        $time = time();
        $file = LOG_PATH . &#39;/&#39; . date(&#39;Y.m.d&#39;) . &#39;_errorlog.php&#39;;
        $hash = md5($message);
        $userId = 0;
        $ip = get_client_ip();
        $user = &#39;<b>User:</b> userId=&#39; . intval($userId) . &#39;; IP=&#39; . $ip . &#39;; RIP:&#39; . $_SERVER[&#39;REMOTE_ADDR&#39;];
        $uri = &#39;Request: &#39; . htmlspecialchars(self::clear($_SERVER[&#39;REQUEST_URI&#39;]));
        $message = "<?php exit;?> {$time} $message $hash $user $uri ";
        // 判断该$message是否在时间间隔$maxtime内已记录过,有,则不用再记录了
        if (is_file($file)) {
            $fp = @fopen($file, &#39;rb&#39;);
            $lastlen = 50000; // 读取最后的 $lastlen 长度字节内容
            $maxtime = 60 * 10; // 时间间隔:10分钟
            $offset = filesize($file) - $lastlen;
            if ($offset > 0) {
                fseek($fp, $offset);
            }
            if ($data = fread($fp, $lastlen)) {
                $array = explode(" ", $data);
                if (is_array($array)) foreach ($array as $key => $val) {
                    $row = explode(" ", $val);
                    if ($row[0] != &#39;<?php exit;?>&#39;) {
                        continue;
                    }
                    if ($row[3] == $hash && ($row[1] > $time - $maxtime)) {
                        return;
                    }
                }
            }
        }
        error_log($message, 3, $file);
    }
    /**
     * 清除文本部分字符
     *
     * @param string $message
     */
    public static function clear($message) {
        return str_replace(array(
            " ",
            " ",
            " "
        ) , " ", $message);
    }
    /**
     * sql语句字符清理
     *
     * @static
     * @access public
     * @param string $message
     * @param string $dbConfig
     */
    public static function sqlClear($message, $dbConfig) {
        $message = self::clear($message);
        if (!(defined(&#39;SITE_DEBUG&#39;) && SITE_DEBUG)) {
            $message = str_replace($dbConfig[&#39;database&#39;], &#39;***&#39;, $message);
            //$message = str_replace($dbConfig[&#39;prefix&#39;], &#39;***&#39;, $message);
            $message = str_replace(C(&#39;DB_PREFIX&#39;) , &#39;***&#39;, $message);
        }
        $message = htmlspecialchars($message);
        return $message;
    }
    /**
     * 显示错误
     *
     * @static
     * @access public
     * @param string $type 错误类型 db,system
     * @param string $errorMsg
     * @param string $phpMsg
     */
    public static function showError($type, $errorMsg, $phpMsg = &#39;&#39;) {
        global $_G;
        $errorMsg = str_replace(SITE_PATH, &#39;&#39;, $errorMsg);
        ob_end_clean();
        $host = $_SERVER[&#39;HTTP_HOST&#39;];
        $title = $type == &#39;db&#39; ? &#39;Database&#39; : &#39;System&#39;;
        echo <<<EOT
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
 <title>$host - $title Error</title>
 <meta http-equiv="Content-Type" content="text/html; charset={$_G[&#39;config&#39;][&#39;output&#39;][&#39;charset&#39;]}" />
 <meta name="ROBOTS" content="NOINDEX,NOFOLLOW,NOARCHIVE" />
 <style type="text/css">
 <!--
 body { background-color: white; color: black; font: 9pt/11pt verdana, arial, sans-serif;}
 #container {margin: 10px;}
 #message {width: 1024px; color: black;}
 .red {color: red;}
 a:link {font: 9pt/11pt verdana, arial, sans-serif; color: red;}
 a:visited {font: 9pt/11pt verdana, arial, sans-serif; color: #4e4e4e;}
 h1 {color: #FF0000; font: 18pt "Verdana"; margin-bottom: 0.5em;}
 .bg1 {background-color: #FFFFCC;}
 .bg2 {background-color: #EEEEEE;}
 .table {background: #AAAAAA; font: 11pt Menlo,Consolas,"Lucida Console"}
 .info {
  background: none repeat scroll 0 0 #F3F3F3;
  border: 0px solid #aaaaaa;
  border-radius: 10px 10px 10px 10px;
  color: #000000;
  font-size: 11pt;
  line-height: 160%;
  margin-bottom: 1em;
  padding: 1em;
 }
 .help {
  background: #F3F3F3;
  border-radius: 10px 10px 10px 10px;
  font: 12px verdana, arial, sans-serif;
  text-align: center;
  line-height: 160%;
  padding: 1em;
 }
 .sql {
  background: none repeat scroll 0 0 #FFFFCC;
  border: 1px solid #aaaaaa;
  color: #000000;
  font: arial, sans-serif;
  font-size: 9pt;
  line-height: 160%;
  margin-top: 1em;
  padding: 4px;
 }
 -->
 </style>
</head>
<body>
<div id="container">
<h1 id="title-nbsp-Error">$title Error</h1>
<div class=&#39;info&#39;>$errorMsg</div>
EOT;
        if (!empty($phpMsg)) {
            echo &#39;<div class="info">&#39;;
            echo &#39;<p><strong>PHP Debug</strong></p>&#39;;
            echo &#39;<table cellpadding="5" cellspacing="1" width="100%" class="table"><tbody>&#39;;
            if (is_array($phpMsg)) {
                echo &#39;<tr class="bg2"><td>No.</td><td>File</td><td>Line</td><td>Code</td></tr>&#39;;
                foreach ($phpMsg as $k => $msg) {
                    $k++;
                    echo &#39;<tr class="bg1">&#39;;
                    echo &#39;<td>&#39; . $k . &#39;</td>&#39;;
                    echo &#39;<td>&#39; . $msg[&#39;file&#39;] . &#39;</td>&#39;;
                    echo &#39;<td>&#39; . $msg[&#39;line&#39;] . &#39;</td>&#39;;
                    echo &#39;<td>&#39; . $msg[&#39;function&#39;] . &#39;</td>&#39;;
                    echo &#39;</tr>&#39;;
                }
            } else {
                echo &#39;<tr><td><ul>&#39; . $phpMsg . &#39;</ul></td></tr>&#39;;
            }
            echo &#39;</tbody></table></div>&#39;;
        }
        echo <<<EOT
</div>
</body>
</html>
EOT;
        exit();
    }
}
/**
 * DB异常类
 *
 * @author www.phprm.com
 */
class DbException extends Exception {
    protected $sql;
    protected $dbConfig; // 当前数据库配置信息
    public function __construct($message, $code = 0, $sql = &#39;&#39;, $dbConfig = array()) {
        $this->sql = $sql;
        $this->dbConfig = $dbConfig;
        parent::__construct($message, $code);
    }
    public function getSql() {
        return $this->sql;
    }
    public function getDbConfig() {
        return $this->dbConfig;
    }
}
?>
Copy after login

效果图:PHP系统异常处理类程序


Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1666
14
PHP Tutorial
1273
29
C# Tutorial
1255
24
What is the difference between using foreach and iterator to delete elements when traversing Java ArrayList? What is the difference between using foreach and iterator to delete elements when traversing Java ArrayList? Apr 27, 2023 pm 03:40 PM

1. The difference between Iterator and foreach is the polymorphic difference (the bottom layer of foreach is Iterator) Iterator is an interface type, it does not care about the type of collection or array; both for and foreach need to know the type of collection first, even the type of elements in the collection; 1. Why is it said that the bottom layer of foreach is the code written by Iterator: Decompiled code: 2. The difference between remove in foreach and iterator. First, look at the Alibaba Java Development Manual, but no error will be reported in case 1, and an error will be reported in case 2 (java. util.ConcurrentModificationException) first

How to determine the number of foreach loop in php How to determine the number of foreach loop in php Jul 10, 2023 pm 02:18 PM

​The steps for PHP to determine the number of the foreach loop: 1. Create an array of "$fruits"; 2. Create a counter variable "$counter" with an initial value of 0; 3. Use "foreach" to loop through the array, and Increase the value of the counter variable in the loop body, and then output each element and their index; 4. Output the value of the counter variable outside the "foreach" loop to confirm which element the loop reaches.

How to solve PHP Warning: fopen(): SSL operation failed in file.php on line X How to solve PHP Warning: fopen(): SSL operation failed in file.php on line X Aug 25, 2023 am 09:22 AM

How to solve PHPWarning:fopen():SSLoperationfailedinfile.phponlineX In PHP programming, we often use the fopen function to open files or URLs and perform related operations. However, when using the fopen function, sometimes you will encounter something similar to Warning:fopen():SSLoperationfailedinfile.p

How to solve PHP Warning: fopen(): failed to open stream: Permission denied How to solve PHP Warning: fopen(): failed to open stream: Permission denied Aug 20, 2023 pm 01:45 PM

How to solve PHPWarning:fopen():failedtoopenstream:Permissiondenied In the process of developing PHP programs, we often encounter some error messages, such as PHPWarning:fopen():failedtoopenstream:Permissiondenied. This error is usually due to incorrect file or directory permissions

How to solve PHP Warning: fopen(): failed to open stream: No such file or directory How to solve PHP Warning: fopen(): failed to open stream: No such file or directory Aug 19, 2023 am 10:44 AM

How to solve PHPWarning:fopen():failedtoopenstream:Nosuchfileordirectory In the process of using PHP development, we often encounter some file operation problems, one of which is "PHPWarning:fopen():failedtoopenstream:Nosuchfileordirectory"

PHP returns an array with key values ​​flipped PHP returns an array with key values ​​flipped Mar 21, 2024 pm 02:10 PM

This article will explain in detail how PHP returns an array after key value flipping. The editor thinks it is quite practical, so I share it with you as a reference. I hope you can gain something after reading this article. PHP Key Value Flip Array Key value flip is an operation on an array that swaps the keys and values ​​in the array to generate a new array with the original key as the value and the original value as the key. Implementation method In PHP, you can perform key-value flipping of an array through the following methods: array_flip() function: The array_flip() function is specially used for key-value flipping operations. It receives an array as argument and returns a new array with the keys and values ​​swapped. $original_array=[

Usage of fopen function in Matlab Usage of fopen function in Matlab Nov 28, 2023 am 11:03 AM

In Matlab, the fopen function is used to open a file and return the file identifier for subsequent reading or writing operations on the file. Select the appropriate permission options to open the file as needed, and promptly close the file when the operation is complete. It should be noted that after opening a file, you need to ensure that the file is closed in time when it is no longer needed to release system resources. In addition, if the file opening fails or an operation error occurs, the error handling mechanism can be used to handle it accordingly.

How to use PHP explode function and solve errors How to use PHP explode function and solve errors Mar 10, 2024 am 09:18 AM

The explode function in PHP is a function used to split a string into an array. It is very common and flexible. In the process of using the explode function, we often encounter some errors and problems. This article will introduce the basic usage of the explode function and provide some methods to solve the error reports. 1. Basic usage of the explode function In PHP, the basic syntax of the explode function is as follows: explode(string$separator,string$stri

See all articles