错误和异常

错误

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里的异常和错误处理

  1. 出现错误-> 触发->错误的处理handler->错误处理handler抛出异常-》触发异常处理的hander->写日志/格式化输出
  2. 出现异常->触发异常处理的hander→写日志/格式化输出
  3. 出现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

最新文章

  1. 隔天开启tomcat spring报错
  2. [连载]《C#通讯(串口和网络)框架的设计与实现》- 8.总体控制器的设计
  3. JavaScript数组:增删改查、排序等
  4. 深度学习入门教程UFLDL学习实验笔记一:稀疏自编码器
  5. SpringMvc:处理模型数据
  6. javascript和swf在网页中交互的一些总结
  7. HDU 1150 Machine Schedule (最小覆盖,匈牙利算法)
  8. Bridging signals ZOJ 3627 POJ1631 HDU1950
  9. 《鸟哥的Linux私房菜》读书笔记一
  10. [Android学习笔记]使用getIdentifier()获取资源Id
  11. oracle中的赋权
  12. Android 开发笔记___FrameLayout
  13. 应用服务器性能优化 之 消息队列(MQ:Message Queue)
  14. spring创建bean及数据注入
  15. 浅谈开发中python通过os模块存储数据
  16. P2634 [国家集训队]聪聪可可
  17. 2、JUC--CAS算法
  18. bzoj3491: PA2007 Subsets
  19. Oracle SQL Developer保持数据库连接的方法
  20. 解决dos窗口乱码问题

热门文章

  1. Idea集成CSSO插件压缩css文件
  2. 什么是feigin?它的优点是什么?
  3. 如何获取 topic 主题的列表?
  4. jvm-learning-概述
  5. python学习笔记(六)——程序调试
  6. Chrome 已经原生支持截图功能,还可以给节点截图!
  7. video标签学习使用
  8. ajax遍历list数据解决方法
  9. CentOS 7.9 网络配置
  10. nodejs教程---基于expressJs框架,实现文件上传(upload)?