php错误异常及其排错
错误和异常
错误
php程序自身的问题,一般是由非法的语法,环境问题导致
异常
一般是业务逻辑上出现的不合预期、与正常流程不同的状况,不是语法错误
错误异常继承关系
小括号表示php版本
php7下的常见错误异常类型
常见错误/异常代码 | 类型 | try/catch | set_error_handler | set_exception_handler | register_shutdown_function(均触发) |
---|---|---|---|---|---|
include/require "aaa" |
错误 | ||||
undefined() |
异常 | ||||
$arr=["a"=>1];echo $arr['b']; |
错误 | ||||
echo 1/0; |
错误 | ||||
intdiv(1,0) |
异常 | ||||
define("A",1);define("A",1); |
错误 | ||||
function a(); function a();//或者类的重复定义 |
错误 | ||||
function add($a,$b){return $a+$b;} add(1); add(1,2,3);//自动忽略了多余的 |
异常 | ||||
$a=1; foreach ($a as $k=>$v){ echo $k."--".$v; } |
错误 | ||||
include "parseError.php"; //parseError.php 有语法错误 |
异常 | ||||
$a=null; $a->fun(); |
异常 |
错误和异常的有关主要配置
log_errors //开启记录错误日志
display_errors //是否在页面展示错误日志
error_reporting //错误级别
error_log
如果该配置没有设置,则错误信息会被发送到 SAPI 错误记录器。
例如,出现nginx的错误日志中,或者在CLI中发送到 stderr
配置优先级别fpm>ini>nginx
错误/异常有关处理函数
https://www.php.net/manual/zh/ref.errorfunc.php
set_exception_handler
在exception_handler 调用后异常会中止
只能设置1个,未设置则返回NULL,再次设置返回上次的handler(5.5+),设置为NULL和restore_exception_handler()作用类似
set_error_handler
以下级别的错误不能由用户定义的函数来处理,独立于发生错误的地方: E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING,和在 调用 set_error_handler() 函数所在文件中产生的大多数 E_STRICT
如果错误发生在脚本执行之前,将不会 调用自定义的错误处理程序因为它尚未在那时注册
传入 null 重置处理程序到默认状态,同restore_error_handler()
handler里error_types 里指定的错误类型都会绕过 PHP 标准错误处理程序, 除非回调函数返回了 false
如果handler返回 false,标准错误处理处理程序将会继续调用
register_shutdown_function
不影响error_log的行为,可以多个
Yii里的异常和错误处理
- 出现错误-> 触发->错误的处理handler->错误处理handler抛出异常-》触发异常处理的hander->写日志/格式化输出
- 出现异常->触发异常处理的hander→写日志/格式化输出
- 出现fatal错误→触发 register_shutdown_function的handler->写日志/格式化输出
常见的查错
去哪找日志,陌生的项目怎么快速的找到日志
1.去error_log文件找(php-fpm.conf→php.ini→nginx的error_log) 一定要注意日志文件的权限(fpm 的worker进程是否可写)
2.找set_exception_handler,set_error_handler的返回
不找日志,重置错误处理
不想管自定义的错误处理
把错误,异常处理的handeler全部重置掉,只去标准里去找即可
error_reporting(E_ALL);
ini_set("display_errors","On");
restore_exception_handler();
restore_error_handler();
常用调试
基本简单的调试
var_dump(),print_r(),var_export()
Yii框架的帮助函数 比如 yii\helpers\VarDumper::dump/dumpAsString());
调用栈追踪
1.debug_backtrace(int $options = DEBUG_BACKTRACE_IGNORE_ARGS, int $limit = 0)
调用到此处,调用链关系,根据需要传需要的参数,节省开销
2.get_included_files()
按顺序打印加载文件的顺序助于调试
比如常驻的(swoole,workerman)可以通过这个看,修改某个php文件(此处是不是已经加载到内存),用不用重启服务
其它工具
Yii的debugger tool
为了调试方便对其他人不产生影响,可使用种cookie方式开启(外加ip白名单)方式,比较适合yii混编的页面调试
辅助配套的cookie-editor插件
https://chrome.google.com/webstore/detail/cookie-editor/iphcomljdfghbkdcfndaijbokpgddeno?hl=zh-CN
whoops(类似yii debugger tool)
点击左边可以代码到那里
chrome控制台
https://github.com/ccampbell/chromephp
页面有刷新跳转时 可以开启console日志保持模式
性能调试
xhprof+xhgui
xhprof
php错误异常及其排错的更多相关文章
- C#中准确跟踪错误异常所在的文件位置方法
准确跟踪错误异常所在的文件位置方法是在发布改文件所在的DLL时候,把对应的pdb文件也一同发布. pdb文件是:PDB全称Program Database,不知道中文翻译叫什么.相信使用过VS的人对于 ...
- 错误/异常:java.io.FileNotFoundException: .\src\db.properties (系统找不到指定的路径。);的解决方法
1.异常视图 2.解决方法 与之相关的部分代码: static{ try { //读取db.properties Properties props = new Properties(); FileIn ...
- Expo大作战(十七)--expo结合哨兵(sentry)进行错误异常记录
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...
- JAVA-JSP内置对象之exception对象用来处理错误异常
相关资料:<21天学通Java Web开发> exception对象1.exception对象用来处理错误异常.2.如果要使用exception对象,必须指定page中的isErrorPa ...
- JavaScript 错误异常
JavaScript 错误异常 错误异常语句 try 语句测试代码块中的错误 catch 语句处理错误 throw 语句允许自定义错误 finally 语句在错误异常语句后,必须执行的代码块 try ...
- 错误/异常:org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/classes/beans_common.xml]...的解决方法
1.第一个这种类型的异常 1.1.异常信息:org.springframework.beans.factory.BeanCreationException: Error creating bean w ...
- 错误/异常:org.hibernate.InvalidMappingException: Could not parse mapping document from resource com/shore/model/Husband.hbm.xml 的解决方法
1.错误/异常视图 错误/异常描述:无效的映射异常,无法从xxxxx资源中解析映射文档 2.解决方法 出现这个异常,一般情况下是包名写错了.改回来即可. 看报错/异常的第一行,最后面,会提示你 ...
- 错误/异常:org.hibernate.id.IdentifierGenerationException: ids for this class must be manually assigned before calling save() 的解决方法
1.错误/异常视图 错误/异常描述:id的生成错误,在调用save()方法之前,必须先生成id. 2.解决方法 在对应的实体类的主键(id)的get方法上加上:@GeneratedValue( ...
- 错误/异常:org.hibernate.MappingException: Unknown entity: com.shore.entity.Student 的解决方法
1.错误/异常视图 错误/异常描述:Hibernate配置文件 映射异常,不明实体类Student(org.hibernate.MappingException: Unknown entity: co ...
随机推荐
- 使用final关键字修饰一个变量时,是引用不能变,还是引用的对象不能变?
使用final关键字修饰一个变量时,是指引用变量不能变,引用变量所指向的对象中的内容还是可以改变的.例如,对于如下语句: final StringBuilder a=new StringBuilder ...
- 学习k8s(四)
1.K8S核心组件 1.Master节点: etcd: 分布式键值对数据库,保存集群状态 api-server: 接受并响应用户的请求 controller: 控制器管理,控制容器的副本数,故障检测 ...
- http和https到底区别在哪
一.Http和Https的基本概念 Http:超文本传输协议(Http,HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络协议.设计Http最初的目的是为了提供一 ...
- TCP 重传、滑动窗⼝、流量控制、拥塞控制
重传机制 TCP 会在以下两种情况发⽣超时重传: 数据包丢失 确认应答丢失 重传超时 重传超时是TCP协议保证数据可靠性的另一个重要机制,其原理是在发送某一个数据以后就开启一个计时器,在一定时间内如果 ...
- ADAS最全整理
为了实现「无人驾驶」的理想,各大整车厂和供应商目前正在开发「高级驾驶员辅助系统」(ADAS),随着 ADAS 慢慢被完善,车辆也在一步一步从 NHTSa 的 0 级过度到第 4 级,实现完全自动化.& ...
- Linux基础学习 | 用户及用户组
Linux 用户及用户组 目录 一.用户 添加用户实例 二.用户组 添加用户组实例 三.用户及用户组文件 四.各命令参数对照 一.用户 Linux系统是一个多用户多任务的分时操作系统.任何 ...
- 纯干货数学推导_傅里叶级数与傅里叶变换_Part4_傅里叶级数的复数形式
- 探讨:微信小程序应该如何设计
微信小程序公测后,开发者非常热情,都有很高的期待,都想抓住这一波红利.但是热情背后需要冷静,我们需要搞清楚两个问题: 微信想要我们做什么?微信小程序可以做什么? 微信想要我们做什么? 首先来弄清楚微信 ...
- H5使用Canvas绘图
一.什么是Canvas Canvas 是H5的一部分,允许脚本语言动态渲染图像.Canvas 定义一个区域,可以由html属性定义该区域的宽高,javascript代码可以访问该区域,通过一整套完整的 ...
- python-查找鞍点
[题目描述]对于给定5X5的整数矩阵,设计算法查找出所有的鞍点的信息(包括鞍点的值和行.列坐标,坐标从1开始). 提示:鞍点的特点:列上最小,行上最大. [练习要求]请给出源代码程序和运行测试结果 ...