欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php開發(fā)時(shí)容易忘記的一些技術(shù)細(xì)節(jié)

 更新時(shí)間:2016年02月03日 14:33:56   投稿:hebedich  
本文給大家分享的是在使用PHP做開發(fā)的時(shí)候,比較容易忽視的2個(gè)小細(xì)節(jié),分別是empty和in_array,有需要的小伙伴可以來參考下。

在做開發(fā)的時(shí)候,有可能會(huì)忘記掉一些技術(shù)細(xì)節(jié)。這些細(xì)節(jié)有可能會(huì)造成很嚴(yán)重的后果,比如網(wǎng)站被注入、網(wǎng)站崩潰等等?,F(xiàn)在我們總結(jié)一下,有可能會(huì)遇到的一些 PHP 中的一些 “陷阱”。

陷阱一:empty()

<?php
//以下代碼會(huì)直接導(dǎo)致PHP解析錯(cuò)誤
$arr1 = [1, 2, 3];
$arr2 = [3, 4];
if(empty(array_diff($arr1, $arr2))) { //解析錯(cuò)誤
  echo 'empty';
} else {
  echo 'not empty';
}

最新的官網(wǎng)手冊(cè)對(duì)此有特別說明:

Note:

在 PHP 5.5 之前,empty() 僅支持變量;任何其他東西將會(huì)導(dǎo)致一個(gè)解析錯(cuò)誤。

換言之,下列代碼不會(huì)生效: empty(trim($name))。 作為替代,應(yīng)該使用trim($name) == false.
我最近一次遇到該錯(cuò)誤,是使用 Phalcon 開發(fā)的時(shí)候,服務(wù)器一直報(bào) 503 錯(cuò)誤,剛開始會(huì)覺得莫名其妙,通過逐行排除,才發(fā)生由于 empty 的錯(cuò)誤用法導(dǎo)致的。當(dāng)然,自從 PHP 5.5 開始,empty 已經(jīng)支持這種寫法了。

陷阱二:in_array()

<?php
//判斷數(shù)組里是否存在用戶所提交的用戶 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';
}
//輸出結(jié)果:find me,此結(jié)果明顯錯(cuò)誤

我發(fā)現(xiàn)這個(gè)問題,是因?yàn)榫W(wǎng)站被 SQL 注入了,還好,那么時(shí)候在測(cè)試的時(shí)候發(fā)現(xiàn)的,沒有造成嚴(yán)重的后果。

關(guān)于 in_array() 函數(shù)使用,還有其他值得我們注意的地方,PHP 手冊(cè)中,有大量的網(wǎng)友提供的示例,來說明該函數(shù)的“怪異”行為,比如:

<?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

為了安全起見,建議可以采用下面這種方式進(jìn)行判斷:

<?php
//判斷數(shù)組里是否存在用戶提交的 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';
}
//輸出結(jié)果:do not find me,這是正確的結(jié)果

相關(guān)文章

  • PHP連接SQLServer2005 的問題解決方法

    PHP連接SQLServer2005 的問題解決方法

    關(guān)于PHP連接MSSQL這個(gè)問題煩了我好幾天,一開始在XP上怎么試也不行,MSSQL模塊怎么也加載不上。
    2010-07-07
  • PHP中Echo結(jié)構(gòu)的用法

    PHP中Echo結(jié)構(gòu)的用法

    PHP echo嚴(yán)格來說是一個(gè)語言結(jié)構(gòu)(language construct)而不是一個(gè)函數(shù),echo的功用是用來輸出字串,是使用率非常高的一個(gè)語言結(jié)構(gòu),特別是未使用樣版模式的系統(tǒng),與echo類似的還有print,兩者差別并不大,普通的時(shí)候,其實(shí)使用echo就可以了
    2022-06-06
  • php按單詞截取字符串的方法

    php按單詞截取字符串的方法

    這篇文章主要介紹了php按單詞截取字符串的方法,涉及php操作字符串的技巧,需要的朋友可以參考下
    2015-04-04
  • php查看當(dāng)前Session的ID實(shí)例

    php查看當(dāng)前Session的ID實(shí)例

    這篇文章主要介紹了php查看當(dāng)前Session的ID的方法,實(shí)例分析了兩種常見的獲取session中ID的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-03-03
  • PHP實(shí)現(xiàn)找出鏈表中環(huán)的入口節(jié)點(diǎn)

    PHP實(shí)現(xiàn)找出鏈表中環(huán)的入口節(jié)點(diǎn)

    這篇文章主要介紹了PHP實(shí)現(xiàn)找出鏈表中環(huán)的入口節(jié)點(diǎn),涉及php針對(duì)環(huán)形鏈表的遍歷、查找、計(jì)算等相關(guān)操作技巧,需要的朋友可以參考下
    2018-01-01
  • php下pdo的mysql事務(wù)處理用法實(shí)例

    php下pdo的mysql事務(wù)處理用法實(shí)例

    這篇文章主要介紹了php下pdo的mysql事務(wù)處理用法,以實(shí)例形式分析了基于pdo的事物提交與回滾操作的用法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-12-12
  • PHP JSON格式數(shù)據(jù)交互實(shí)例代碼詳解

    PHP JSON格式數(shù)據(jù)交互實(shí)例代碼詳解

    此前我寫了不少在PHP網(wǎng)站開發(fā)中應(yīng)用XML進(jìn)行數(shù)據(jù)交互的實(shí)例,這兩天通過PHP解析JSON并進(jìn)行交互的實(shí)例學(xué)習(xí)和了解了JSON在PHP中的應(yīng)用,感覺非常方便。
    2011-01-01
  • PHP面向?qū)ο笪宕笤瓌t之單一職責(zé)原則(SRP)詳解

    PHP面向?qū)ο笪宕笤瓌t之單一職責(zé)原則(SRP)詳解

    這篇文章主要介紹了PHP面向?qū)ο笪宕笤瓌t之單一職責(zé)原則(SRP),結(jié)合實(shí)例形式詳細(xì)分析了單一職責(zé)原則(SRP)的概念、原理、定于與使用方法,需要的朋友可以參考下
    2018-04-04
  • PHP回調(diào)函數(shù)與匿名函數(shù)實(shí)例詳解

    PHP回調(diào)函數(shù)與匿名函數(shù)實(shí)例詳解

    這篇文章主要介紹了PHP回調(diào)函數(shù)與匿名函數(shù),結(jié)合實(shí)例形式分析了php回調(diào)函數(shù)與匿名函數(shù)的具體功能、用法及相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2017-08-08
  • PHP 偽靜態(tài)隱藏傳遞參數(shù)名的四種方法

    PHP 偽靜態(tài)隱藏傳遞參數(shù)名的四種方法

    PHP偽靜態(tài)的使用主要是為了隱藏傳遞的參數(shù)名,今天介紹的PHP偽靜態(tài)的方法總共有四種方法以加深對(duì)PHP偽靜態(tài)的了解。
    2010-02-02

最新評(píng)論