本文主要是介绍适用于学习的错误处理实例到工具类PHP,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
(1)错误处理实例:
<html>
<head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8" /><title>错*处理</title>
</head>
<body><h1>登录页面</h1><form action="error_set.php" method='get'>用户名:<input type="text" name="username" id="" /><br />密码:<input type="password" name="password" id="" /><br /><input type="submit" value="登录" /></form></body></html><?php /**********************************打开显示错误'总开关'********************************//***方式一:打开php.ini,设置如下***/
//display_errors = On
//方式二:
ini_set('log_errors', 1); //打开记录错误到日志功能/*************************** *******设置错误级别**********************************//***方式一:通过修改PHP配置文件中的error_reporting选项的值***/
//打开php.ini,设置如下:
//error_reporting = E_ALL 显示所有类型的错误
//error_reporting = E_ALL & ~E_NOTICE 除了NOTICE类型错误,其他所有错误都显示/***方式二:通过eror_reporting()函数设置****/
//设置显示所有级别的错误
error_reporting(-1); //所有错误级别/*************************** *******基本设置**********************************/
header('content-type:text/html;charset=utf-8');
ini_set('date.timezone', 'PRC'); //设置时区
ini_set('diaplay_errors', 0); //界面上不显示错误/********错误日志信息记录到指定文件中*************/
//ini_set('error_log', 'D:/123.log');
/********错误日志信息记录到系统中*************/
//ini_set('error_log', 'syslog');//错误日志在系统的 事件查看器=》管理时间的摘要=》信息 可以查看ini_set('ignore_repeated_errors', 'on'); //忽略重复错误
ini_set('ignore_repeated_source', 'on'); //忽略重复错误的来源$username = isset($_GET['username'])?$_GET['username']:'';
$password = isset($_GET['password'])?$_GET['password']:'';if($username=='admin'&&$password=='admin'){echo "登录成功";exit();
}else {$date=date("Y-m-d H:i:s",time());$ip=$_SERVER['REMOTE_ADDR'];$message="用户:{$username}在{$date}以密码:{$password}尝试登录系统!IP地址为{$ip}";error_log($message);header('login.html');
}?>
(2)错误处理工具类
<?php
class MyErrorHandler{public $message='';public $filename='';public $line=0;public $vars=array();protected $vars=array();protected $_noticeLog='G:\notice\noticeLog.log';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($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();break;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;return error_log($errorMsg,1,'793067016@qq.com');}/*** 处理通知错误*/public function dealNotice(){$datetime = date("Y-m-d H:i:s",time());$errorMsg=<<<EOF
出现了通知错误,如下:
产生错误的文件:{$this->filename}
产生错误的信息:{$this->message}
产生错误的行号:{$this->line}
时间信息:{$datetime}
EOF;return error_log($errorMsg,1,'793067016@qq.com');exit(1);//继续执行其他代码}/*** 处理警告错误*/public function dealWarning(){$errorMsg=<<<EOF
出现了通知错误,如下:
产生错误的文件:{$this->filename}
产生错误的信息:{$this->message}
产生错误的行号:{$this->line}
EOF;return error_log($errorMsg,1,'793067016@qq.com');}}?>
内容来源于慕课网
这篇关于适用于学习的错误处理实例到工具类PHP的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!