加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP编程:php开发时容易忘记的一些技术细节

发布时间:2020-12-13 03:07:13 所属栏目:PHP教程 来源:网络整理
导读:《php开发时容易忘记的一些技术细节》要点: 本文介绍了php开发时容易忘记的一些技术细节,希望对您有用。如果有疑问,可以联系我们。 PHP实例 在做开发的时候,有可能会忘记掉一些技术细节.这些细节有可能会造成很严重的后果,比如网站被注入、网站瓦解等等.

《php开发时容易忘记的一些技术细节》要点:
本文介绍了php开发时容易忘记的一些技术细节,希望对您有用。如果有疑问,可以联系我们。

PHP实例在做开发的时候,有可能会忘记掉一些技术细节.这些细节有可能会造成很严重的后果,比如网站被注入、网站瓦解等等.现在我们总结一下,有可能会遇到的一些 PHP 中的一些 “陷阱”.

PHP实例陷阱一:empty()

PHP实例
<?php
//以下代码会直接导致PHP解析差错
$arr1 = [1,2,3];
$arr2 = [3,4];
if(empty(array_diff($arr1,$arr2))) { //解析差错
  echo 'empty';
} else {
  echo 'not empty';
}

PHP实例最新的官网手册对此有特别说明:

PHP实例Note:

PHP实例
在 PHP 5.5 之前,empty() 仅支持变量;任何其他东西将会导致一个解析差错.

PHP实例换言之,下列代码不会生效: empty(trim($name)). 作为替代,应该使用trim($name) == false.
我最近一次遇到该差错,是使用 Phalcon 开发的时候,服务器一直报 503 差错,刚开始会觉得莫名其妙,通过逐行排除,才发生由于 empty 的差错用法导致的.当然,自从 PHP 5.5 开始,empty 已经支持这种写法了.

PHP实例陷阱二:in_array()

PHP实例
<?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,此结果明显差错

PHP实例我发现这个问题,是因为网站被 SQL 注入了,还好,那么时候在测试的时候发现的,没有造成严重的后果.

PHP实例关于 in_array() 函数使用,还有其他值得我们注意的地方,PHP 手册中,有大量的网友提供的示例,来说明该函数的“怪异”行为,好比:

PHP实例
<?php
 $a = ['a',32,true,'x' => 'y'];
 var_dump(in_array(25,$a)); // true,one would expect false
 var_dump(in_array('ggg',one would expect false
 var_dump(in_array(0,$a)); // true
 var_dump(in_array(null,$a)); // false

PHP实例为了平安起见,建议可以采用下面这种方式进行判断:

PHP实例
<?php
//判断数组里是否存在用户提交的 ID
//$post_dirty_id = '1092';
$post_dirty_id = '1092 ORDER BY #1';
$safe_arr = [
  987 => '小明',1256 => '奥立升'
];
if(isset($safe_arr[$post_dirty_id])) {
  echo 'find me';
} else {
  echo 'do not find me';
}
//输出成果:do not find me,这是正确的成果

编程之家培训学院每天发布《php开发时容易忘记的一些技术细节》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。

(编辑:李大同)

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

    推荐文章
      热点阅读