学会php又忘了,php开发时容易忘记的一些技术细节

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

陷阱一:empty()

//以下代码会直接导致PHP解析错误

$arr1 = [1, 2, 3];

$arr2 = [3, 4];

if(empty(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()

//判断数组里是否存在用户所提交的用户 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 手册中,有大量的网友提供的示例,来说明该函数的“怪异”行为,比如:

$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

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

//判断数组里是否存在用户提交的 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,这是正确的结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值