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和ACCESS写聊天室(五)
Oct 09 PHP
PHP几个数学计算的内部函数学习整理
Aug 06 PHP
浅析PHP 按位与或 (^ 、&amp;)
Jun 21 PHP
php使用websocket示例详解
Mar 12 PHP
php通过隐藏表单控件获取到前两个页面的url
Sep 09 PHP
PHP中$this和$that指针使用实例
Jan 06 PHP
PHP实现的迷你漂流瓶
Jul 29 PHP
php猜单词游戏
Sep 29 PHP
Thinkphp框架 表单自动验证登录注册 ajax自动验证登录注册
Dec 27 PHP
PHP PDOStatement::setFetchMode讲解
Feb 03 PHP
浅析PHP中的 inet_pton 网络函数
Dec 16 PHP
PHP设计模式之命令模式示例详解
Dec 20 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
德生BCL3000的电路分析和打磨
2021/03/02 无线电
PHP脚本数据库功能详解(上)
2006/10/09 PHP
PHP Global变量定义当前页面的全局变量实现探讨
2013/06/05 PHP
PHP版QQ互联OAuth示例代码分享
2015/07/05 PHP
PHP中常用的数组操作方法笔记整理
2016/05/16 PHP
php使用CutyCapt实现网页截图保存的方法
2016/10/03 PHP
JQuery.Ajax之错误调试帮助信息介绍
2013/07/04 Javascript
根据身份证号自动输出相关信息(籍贯,出身日期,性别)
2013/11/15 Javascript
js获取页面传来参数的方法
2014/09/06 Javascript
JavaScript 事件绑定及深入
2015/04/13 Javascript
angularjs 获取默认选中的单选按钮的value方法
2018/02/28 Javascript
Vue全局分页组件的实现代码
2018/08/10 Javascript
Node.js+ELK日志规范的实现
2019/05/23 Javascript
vue实现搜索过滤效果
2019/05/28 Javascript
vue 全局环境切换问题
2019/10/27 Javascript
Vue-cli3多页面配置详解
2020/03/22 Javascript
VUE使用axios调用后台API接口的方法
2020/08/03 Javascript
nodejs+express最简易的连接数据库的方法
2020/12/23 NodeJs
[04:40]2016个国际邀请赛中国区预选赛场地——华西村观战指南
2016/06/25 DOTA
[08:06]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Elephant 选手采访
2021/03/11 DOTA
详解Django缓存处理中Vary头部的使用
2015/07/24 Python
玩转python爬虫之爬取糗事百科段子
2016/02/17 Python
Python使用正则表达式过滤或替换HTML标签的方法详解
2017/09/25 Python
pandas的object对象转时间对象的方法
2018/04/11 Python
python3写的简单本地文件上传服务器实例
2018/06/04 Python
Python函数参数类型及排序原理总结
2019/12/19 Python
Python实现屏幕录制功能的代码
2020/03/02 Python
Python paramiko使用方法代码汇总
2020/11/20 Python
HTML5实现锚点时请使用id取代name
2013/09/06 HTML / CSS
2014年安全生产大检查方案
2014/05/13 职场文书
服装设计专业自荐信
2014/06/17 职场文书
公共场所禁烟标语
2014/06/25 职场文书
小学运动会演讲稿
2014/08/25 职场文书
物联网工程专业推荐信
2014/09/08 职场文书
关于空气污染危害的感想
2015/08/11 职场文书
springcloud整合seata
2022/05/20 Java/Android