PHP批斗大会之缺失的异常详解


Posted in PHP onJuly 09, 2019

故事的开始

这几天观察错误日志发现有一个数据反序列化的notice错误,实际情况我是从缓存中读取数据然后反序列化,因为反序列化失败,所以实际每次都是去数据库取的值。背后性能影响还是挺大的。

缺失的异常

刚开始写代码的时候一直不明白为什么要用异常,感觉if else就能搞定了,为什么还要多此一举,现在反而觉得 php 的异常太少。

对比两种序列化场景,一个是json,另一个是serialize。

json

在json encode/decode的时候,如果出现异常,可以通过json_last_error()来获取。

https://www.php.net/manual/en...

这样的设计只能说勉强够用,不太符合面向对象的套路。

serialize/unserialize

在使用自带的序列化和反序列化的时候,相比json的处理,则更加简单粗暴,没有函数能拿到最后的错误,只会通过自定义的error handler来接管,然后自己去做出一些相应的处理。

为什么要捕获异常

比如我的代码比较乱,有的 key 是 json 序列化,有的 key 是 serialize。我们可以将 key 分类。不能确保其他人配置的对应关系是对的,或者有的人忘记了,所以我需要用捕获异常的方式来兜底,这样我们的代码更加健壮一些。当unserialize失败之后,我们可以尝试去json_decode,而不是立即返回一个false,从而把请求传递到数据库。

代码演示

error_reporting(E_ALL);

$a = ["a" => 1];

class UnSerializeException extends ErrorException
{

}

set_error_handler(function ($severity, $message, $file, $line) {
  $info = explode(":", $message);

  if ($severity == E_NOTICE) {
    if ($info[0] == "unserialize()") {
      throw new UnSerializeException($message);
    }
    return true;
  } else {

    throw new ErrorException($message, 0, $severity, $file, $line);;
  }
});


try {
  $b = unserialize(json_encode($a));
} catch (ErrorException $exception) {
  var_dump(get_class($exception), $exception->getMessage(), $exception->getTraceAsString()); // 捕获到了
} finally {
  restore_error_handler();
}

try {
  $b = unserialize(json_encode($a));
} catch (ErrorException $exception) {
  var_dump(get_class($exception), $exception->getMessage(), $exception->getTraceAsString()); // 无法捕获
}

输出结果

string(20) "UnSerializeException"
string(43) "unserialize(): Error at offset 0 of 7 bytes"
string(181) "#0 [internal function]: {closure}(8, 'unserialize(): ...', '/Users/mengkang...', 34, Array)
#1 /Users/mengkang/PhpstormProjects/xxx/test.php(34): unserialize('{"a":1}')
#2 {main}"

Notice: unserialize(): Error at offset 0 of 7 bytes in /Users/mengkang/PhpstormProjects/xxx/test.php on line 42

后记

所以 php 代码的异常设计还是任重而道远的,而这些已经设定的“旧的规范”要推翻,需要“勇气”,毕竟会影响所有的使用者。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

PHP 相关文章推荐
一个简单实现多条件查询的例子
Oct 09 PHP
PHP入门速成教程
Mar 19 PHP
PHP MYSQL乱码问题,使用SET NAMES utf8校正
Nov 30 PHP
PHP错误抑制符(@)导致引用传参失败Bug的分析
May 02 PHP
7个鲜为人知却非常实用的PHP函数
Jul 01 PHP
PHP getallheaders无法获取自定义头(headers)的问题
Mar 23 PHP
浅谈PHP正则中的捕获组与非捕获组
Jul 18 PHP
centos+php+coreseek+sphinx+mysql之一coreseek安装篇
Oct 25 PHP
php中简单的对称加密算法实现
Jan 05 PHP
php读取和保存base64编码的图片内容
Apr 22 PHP
PHP基于session.upload_progress 实现文件上传进度显示功能详解
Aug 09 PHP
基于laravel缓冲cache的用法详解
Oct 23 PHP
PHP结合Redis+MySQL实现冷热数据交换应用案例详解
Jul 09 #PHP
PHP+Redis开发的书签案例实战详解
Jul 09 #PHP
使用composer命令加载vendor中的第三方类库 的方法
Jul 09 #PHP
Laravel+Intervention实现上传图片功能示例
Jul 09 #PHP
Laravel框架实现多个视图共享相同数据的方法详解
Jul 09 #PHP
Laravel5.1框架注册中间件的三种场景详解
Jul 09 #PHP
PHP使用 Pear 进行安装和卸载包的方法详解
Jul 08 #PHP
You might like
PHP5常用函数列表(分享)
2013/06/07 PHP
windwos下使用php连接oracle数据库的过程分享
2014/05/26 PHP
php封装的smarty类完整实例
2016/10/19 PHP
ThinkPHP实现转换数据库查询结果数据到对应类型的方法
2017/11/16 PHP
extjs3 combobox取value和text案例详解
2013/02/06 Javascript
给html超链接设置事件不使用href来完成跳
2014/04/20 Javascript
jQuery中not()方法用法实例
2015/01/06 Javascript
jQuery选择器源码解读(六):Sizzle选择器匹配逻辑分析
2015/03/31 Javascript
JavaScript模版引擎的基本实现方法浅析
2016/02/15 Javascript
第一次接触JS require.js模块化工具
2016/04/17 Javascript
第三篇Bootstrap网格基础
2016/06/21 Javascript
JS+WCF实现进度条实时监测数据加载量的方法详解
2017/12/19 Javascript
使用Vue.js和Element-UI做一个简单登录页面的实例
2018/02/23 Javascript
使用Vue.js和Flask来构建一个单页的App的示例
2018/03/21 Javascript
js循环map 获取所有的key和value的实现代码(json)
2018/05/09 Javascript
vue内置组件transition简单原理图文详解(小结)
2018/07/12 Javascript
使用异步组件优化Vue应用程序的性能
2019/04/28 Javascript
详解vue-cli中使用rem,vue自适应
2019/05/06 Javascript
Python中使用logging模块打印log日志详解
2015/04/05 Python
Python实现对文件进行单词划分并去重排序操作示例
2018/07/10 Python
Python实现的IP端口扫描工具类示例
2019/02/15 Python
Python常见的pandas用法demo示例
2019/03/16 Python
使用TFRecord存取多个数据案例
2020/02/17 Python
python实现在线翻译功能
2020/03/03 Python
Django form表单与请求的生命周期步骤详解
2020/06/07 Python
解决python3.x安装numpy成功但import出错的问题
2020/11/17 Python
Algenist奥杰尼官网:微藻抗衰老护肤品牌
2017/07/15 全球购物
保险专业大专生求职信
2013/10/26 职场文书
《长征》教学反思
2014/04/27 职场文书
心理健康活动总结
2014/04/30 职场文书
食品科学与工程专业毕业生求职信范文
2014/07/21 职场文书
个人自我剖析材料
2014/09/30 职场文书
小学教师学习党的群众路线教育实践活动心得体会
2014/10/31 职场文书
深入开展党的群众路线教育实践活动心得体会
2014/11/05 职场文书
求职简历自我评价范文
2015/03/10 职场文书
高一英语教学反思
2016/03/03 职场文书