PHP自定义错误处理的方法分析


Posted in PHP onDecember 19, 2018

本文实例讲述了PHP自定义错误处理的方法。分享给大家供大家参考,具体如下:

自定义错误报告的处理方式,可以完全绕过标准的PHP错误处理函数,这样就可以按照自己定义的格式打印错误报告,或改变错误报告打印的位置(标准PHP的错误报告是哪里发生错误就在发生位置处显示)。以下几种情况可以考虑自定义错误处理。

★可以记下错误的信息,及时发现一些生产环境出现的问题。

★可以用来屏蔽错误。出现错误会把一些信息暴漏给用户,极有可能成为黑客攻击你网站的工具。

★可以做相应的处理,将所有错误报告放到脚本最后输出,或出错时可以显示跳转到预先定义好的出错页面,提供更好的用户体验,如果必要,还可以在自定义错误处理程序中,根据情况去终止脚本运行。

★可以作为调试工具,一些时候必须在运行环境时调试一些东西,但又不想影响正在使用的用户。

通常使用set_error_handler()函数去设置用户自定义的错误处理函数,该函数用于创建运行时期间的用户自己的错误处理方法,返回旧的错误处理程序,若失败,则返回null。该函数有两个参数,其中第一个参数是必选的,需要一个回调函数,规定发生错误时运行的函数。这个回调函数一定要声明4个参数,否则无效,按顺序分别为“是否存在错误”、“错误信息”、“错误文件”和“错误行号”。set_error_handler()函数的第二个参数则为可选的,规定现在哪个错误报告级别会显示用户自定义的错误。默认是“E_ALL”。自定义错误处理的示例如下所示:

<?php
error_reporting(0); //屏蔽程序中的错误
//定义Error_Handler函数,作为set_error_handler()函数的第一个参数“回调”
function error_handler($error_level,$error_message,$file,$line){
$EXIT =FALSE;
switch($error_level){
//提醒级别
case E_NOTICE:
case E_USER_NOTICE:
$error_type = 'Notice';
break;
//警告级别
case E_WARNING:
case E_USER_WARNING:
$error_type='warning';
break;
//错误级别
case E_ERROR:
case E_USER_ERROR:
$error_type='Fatal Error';
$EXIT = TRUE;
break;
//其他未知错误
default:
$error_type='Unknown';
$EXIT = TRUE;
break;
}
//直接打印错误信息,也可以写文件,写数据库,反正错误信息都在这,任你发落
printf("<font color='#FF0000'><b>%s</b></font>:%s in<b>%s</b> on line <b>%d</b><br>\n",$error_type, $error_message, $file, $line);
//如果错误影响到程序的正常执行,跳转到友好的错误提示页面
if (TURE==$EXIT){
echo '<script>location = "err.html";</scrpit>';
}
}
//这个才是关键点,把错误的处理交给error_handle()
set_error_handler('error_handler');
//使用未定义的变量要报notice的
echo $novar;
//除以0要报警告的
echo 3/0;
//自定义一个错误
trigger_error('Trigger a fatal error',E_USER_ERROR);
?>

本例所有打印的错误报告都是按自己定义的格式输出的,不过有一点,系统直接报Fatal Error的这里捕获不到,因为系统不可能把这么重大的错误教给你处理。遇到这种错误是必须要解决的,所以系统会直接终止程序运行。使用set_error_handler()函数可以很好地解决安全和调试方便的矛盾,而且你还可以花点心思,使错误提示更加美观以配合网站的风格。不过要注意两点。

E_ERRORE_PARSEE_CORE_ERRORE_CORE_WARNINGE_COMPILE_ERRORE_COMPILE_WARNING是不会被这个句柄处理的,也就是会用最原始的方式显示出来。不过出现这些错误都是编译或PHP内核出错,在通常情况下不会发生。

②使用set_error_handler()后,error_reporting()将会失效。也就是所有的错误(除上述的错误)都会教给自己定义的函数处理。

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

PHP 相关文章推荐
PHP原理之异常机制深入分析
Aug 08 PHP
Linux Apache PHP Oracle 安装配置(具体操作步骤)
Jun 17 PHP
php自动加载autoload机制示例分享
Feb 20 PHP
php如何解决无法上传大于8M的文件问题
Mar 10 PHP
Linux下安装oracle客户端并配置php5.3
Oct 12 PHP
浅析PHP关键词替换的类(避免重复替换,保留与还原原始链接)
Sep 22 PHP
PHP创建word文档的方法(平台无关)
Mar 29 PHP
PHP的PDO常用类库实例分析
Apr 07 PHP
Yii实现Command任务处理的方法详解
Jul 14 PHP
常用PHP数组排序函数归纳
Aug 08 PHP
PHP 实现浏览记录并按日期分组
May 11 PHP
thinkphp查询,3.X 5.0方法(亲试可行)
Jun 17 PHP
PHP异常类及异常处理操作实例详解
Dec 19 #PHP
PHP单例模式应用示例【多次连接数据库只实例化一次】
Dec 18 #PHP
PHP时间戳和日期相互转换操作实例小结
Dec 18 #PHP
PHP获取星期几的常用方法小结
Dec 18 #PHP
php往mysql中批量插入数据实例教程
Dec 12 #PHP
yii2 url重写并隐藏index.php方法
Dec 10 #PHP
php 处理png图片白色背景色改为透明色的实例代码
Dec 10 #PHP
You might like
《超神学院》霸气归来, 天使彦上演维多利亚的秘密
2020/03/02 国漫
PHP分页显示制作详细讲解
2008/11/19 PHP
简单实现限定phpmyadmin访问ip的方法
2013/03/05 PHP
destoon实现调用自增数字从1开始的方法
2014/08/21 PHP
php生成百度sitemap站点地图类函数实例
2014/10/17 PHP
php字符串替换函数substr_replace()用法实例
2015/03/17 PHP
jQuery实现公告文字左右滚动的实例代码
2013/10/29 Javascript
Javascript前端UI框架Kit使用指南之Kitjs简介
2014/11/28 Javascript
14款经典网页图片和文字特效的jQuery插件-前端开发必备
2015/08/25 Javascript
基于jquery实现ajax无刷新评论
2020/08/19 Javascript
AngularJS前端页面操作之用户修改密码功能示例
2017/03/27 Javascript
nodejs微信开发之授权登录+获取用户信息
2019/03/17 NodeJs
JS判断数组里是否有重复元素的方法小结
2019/05/21 Javascript
JS面向对象之单选框实现
2020/01/17 Javascript
基于原生js实现九宫格算法代码实例
2020/07/03 Javascript
[00:12]DAC2018 天才少年转战三号位,他的SOLO是否仍如昔日般强大?
2018/04/06 DOTA
在Python中操作列表之List.append()方法的使用
2015/05/20 Python
python-opencv在有噪音的情况下提取图像的轮廓实例
2017/08/30 Python
解决Spyder中图片显示太小的问题
2018/04/27 Python
对Python中9种生成新对象的方法总结
2018/05/23 Python
使用python语言,比较两个字符串是否相同的实例
2018/06/29 Python
python 读取文件并替换字段的实例
2018/07/12 Python
Python实现将Excel转换成xml的方法示例
2018/08/25 Python
python如何查看微信消息撤回
2018/11/27 Python
Python完全识别验证码自动登录实例详解
2019/11/24 Python
Python遍历字典方式就实例详解
2019/12/28 Python
python如何把字符串类型list转换成list
2020/02/18 Python
啤酒销售实习自我鉴定
2013/09/24 职场文书
幼师专业毕业生自荐信
2013/09/29 职场文书
防灾减灾日活动总结
2014/08/26 职场文书
公务员群众路线专题民主生活会发言材料
2014/09/17 职场文书
国防教育标语
2014/10/08 职场文书
先进工作者推荐材料
2014/12/23 职场文书
2015年世界无烟日演讲稿
2015/03/18 职场文书
Python Django框架介绍之模板标签及模板的继承
2021/05/27 Python
浅谈PostgreSQL表分区的三种方式
2021/06/29 PostgreSQL