加入收藏 | 设为首页 | 会员中心 | 我要投稿 菏泽站长网 (https://www.0530zz.cn/)- 数据工坊、负载均衡、数据快递、云计算、事件网格!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php开发时容易忘记的一些技术细节

发布时间:2022-07-16 10:30:49 所属栏目:PHP教程 来源:互联网
导读:本文给大家分享的是在使用PHP做开发的时候,比较容易忽视的2个小细节,分别是empty和in_array,有需要的小伙伴可以来参考下。 在做开发的时候,有可能会忘记掉一些技术细节,这些细节有可能会造成很严重的后果,比如网站被注入、网站崩溃等等,现在我们总结
  本文给大家分享的是在使用PHP做开发的时候,比较容易忽视的2个小细节,分别是empty和in_array,有需要的小伙伴可以来参考下。
 
  在做开发的时候,有可能会忘记掉一些技术细节,这些细节有可能会造成很严重的后果,比如网站被注入、网站崩溃等等,现在我们总结一下,有可能会遇到的一些 PHP 中的一些 “陷阱”。
 
  陷阱一:empty()
 
  <?php
  //以下代码会直接导致PHP解析错误
  $arr1 = [1, 2, 3];
  $arr2 = [3, 4];
  if(emptyempty(array_diff($arr1, $arr2))) { //解析错误
    echo 'empty';
  } else {
    echo 'not empty';
  }
  最新的官网手册对此有特别说明:
 
  Note:
 
  在 PHP 5.5 之前,empty() 仅支持变量;任何其他东西将会导致一个解析错误。
 
  换言之,下列代码不会生效: empty(trim($name))。 作为替代,应该使用trim($name) == false.
 
  我最近一次遇到该错误,是使用 Phalcon 开发的时候,服务器一直报 503 错误,刚开始会觉得莫名其妙,通过逐行排除,才发生由于 empty 的错误用法导致的。当然,自从 PHP 5.5 开始,empty 已经支持这种写法了。
 
  陷阱二:in_array()
 
  <?php
  //判断数组里是否存在用户所提交的用户 ID
  //$post_dirty_id = '1092';
  $post_dirty_id = '1092 ORDER BY #1';
  $safe_arr = [
    987 => '小明',
    1092 => '汤姆',
    1256 => '奥立升'
  ];
  if(in_array($post_dirty_id, array_keys($safe_arr))) {
    echo 'find me';
  } else {
    echo 'do not find me';
  }
  输出结果:find me,此结果明显错误
 
  我发现这个问题,是因为网站被 SQL 注入了,还好,那么时候在测试的时候发现的,没有造成严重的后果。
 
  关于 in_array() 函数使用,还有其他值得我们注意的地方,PHP 手册中,有大量的网友提供的示例,来说明该函数的“怪异”行为,比如:
 
  <?php
   $a = ['a', 32, true, 'x' => 'y'];
   var_dump(in_array(25, $a)); // true, one would expect false
   var_dump(in_array('ggg', $a)); // true, one would expect false
   var_dump(in_array(0, $a)); // true
   var_dump(in_array(null, $a)); // false
  为了安全起见,建议可以采用下面这种方式进行判断:
 
  <?php
  //判断数组里是否存在用户提交的 ID
  //$post_dirty_id = '1092';
  $post_dirty_id = '1092 ORDER BY #1';
  $safe_arr = [
    987 => '小明',
    1092 => '汤姆',
    1256 => '奥立升'
  ];
  if(isset($safe_arr[$post_dirty_id])) {
    echo 'find me';
  } else {
    echo 'do not find me';
  }
  输出结果:do not find me,这是正确的结果

(编辑:菏泽站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读