千家信息网

php开发时有哪些容易误入的陷阱

发表于:2024-11-11 作者:千家信息网编辑
千家信息网最后更新 2024年11月11日,这篇文章主要介绍"php开发时有哪些容易误入的陷阱",在日常操作中,相信很多人在php开发时有哪些容易误入的陷阱问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"php开发
千家信息网最后更新 2024年11月11日php开发时有哪些容易误入的陷阱

这篇文章主要介绍"php开发时有哪些容易误入的陷阱",在日常操作中,相信很多人在php开发时有哪些容易误入的陷阱问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"php开发时有哪些容易误入的陷阱"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

陷阱一:empty()

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

Note:

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

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

陷阱二:in_array()

 '小明',  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 手册中,有大量的网友提供的示例,来说明该函数的"怪异"行为,比如:

 '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

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

 '小明',  1092 => '汤姆',  1256 => '奥立升'];if(isset($safe_arr[$post_dirty_id])) {  echo 'find me';} else {  echo 'do not find me';}//输出结果:do not find me,这是正确的结果

到此,关于"php开发时有哪些容易误入的陷阱"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

0