PHP 5.6.22 是一款被廣泛使用的編程語言,尤其在Web開發(fā)中使用頻繁。然而,這個版本中也存在一些安全漏洞,其中最明顯的一個漏洞是在處理HTTP請求時可能導(dǎo)致遠(yuǎn)程代碼執(zhí)行漏洞。
<?php
$url=$_SERVER['PHP_SELF'];
function checkurl($url){
if(preg_match('/^http:\/\/|^ftp:\/\//', $url)){
die('Error:傳入遠(yuǎn)程URL:'.$url.'包含有危險語句.');
}else{
echo '傳入的是本地URL!';
}
}
checkurl($url);
?>
上述代碼片段中,checkurl() 函數(shù)用于檢查傳遞的URL是否是本地URL,如果是遠(yuǎn)程URL,則結(jié)束程序運(yùn)行輸出錯誤信息。但是這個代碼片段還是存在安全漏洞的。攻擊者可以通過構(gòu)造特殊的請求,在傳遞URL參數(shù)時通過 HTTP 協(xié)議文件下載相關(guān)函數(shù)進(jìn)行遠(yuǎn)程代碼執(zhí)行。
例如,以下請求URL:
http://www.example.com/index.php?url=php://filter/convert.base64-encode/resource=dbconnect.php
其中的 "php://filter/" 前綴會導(dǎo)致 PHP 解釋器把請求的東西當(dāng)做參數(shù)進(jìn)行解析。攻擊者可以利用 "convert.base64-encode" 將代碼轉(zhuǎn)換為 Base64 編碼的字符串,并且通過 "resource=" 參數(shù)實現(xiàn)訪問數(shù)據(jù)庫連接文件。最終,這個字符串裝在 URL 參數(shù)中,發(fā)往目標(biāo)服務(wù)端。
$url=$_GET['url'];
if(preg_match("/^http:\/\/|^ftp:\/\//i",$url)){
exit("Error:傳入遠(yuǎn)程URL:".$url."包含有危險語句.");
}else{
readfile($url);
}
上述代碼片段實現(xiàn)了通過讀取文件內(nèi)容的方式,把本地文件直接讀取出來展示給用戶。但是,這里仍然存在一些漏洞。攻擊者可以通過下載文件的方式來實現(xiàn)執(zhí)行任意代碼。例如以下的URL請求:
http://www.example.com/index.php?url=file:///etc/passwd
在上述請求URL中,攻擊者可以通過在URL參數(shù)前面加上 "file:///" 前綴,來達(dá)到讀取系統(tǒng)敏感文件的目的。因此,代碼中應(yīng)當(dāng)增加一些安全機(jī)制,防止外部惡意攻擊。
雖然以上實例可以用較簡單的代碼來解決漏洞問題,但如果運(yùn)用不當(dāng),仍然有可能存在著其他未知的安全漏洞,因此,在開發(fā)過程中需要多加注意,盡量編寫安全的代碼,防止出現(xiàn)漏洞問題。