亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

PHP安全-文件名操縱

瀏覽:118日期:2022-09-12 08:07:18
文件名操縱

在很多情形下會使用動態包含,此時目錄名或文件名中的部分會保存在一個變量中。例如,你可以緩存你的部分動態頁來降低你的數據庫服務器的負擔。

<?php

include '/cache/{$_GET[’username’]}.html';

?>

為了讓這個漏洞更明顯,示例中使用了$_GET。如果你使用了受污染數據時,這個漏洞同樣存在。使用$_GET[’username’]是一個極端的例子,通過它可以把問題看得更清楚。

雖然上面的流程有其優點,但它同時為攻擊者提供了一個可以自由選擇緩存頁的良機。例如,一個用戶可以方便地通過編輯URL中的username的值來察看其他用戶的緩存文件。事實上,攻擊者可以通過簡單的更改username的值為相應的文件名(不加擴展名)來察看/cache目錄下的所有擴展名為.html的文件。

http://example.org/index.php?username=filename

盡管該程序限制了攻擊者所操作的目錄和文件名,但變更文件名并不是唯一的手段。攻擊者可以創造性地達到在文件系統中進行跨越的目的,而去察看其他目錄中的.html文件以發現敏感信息。這是因為可以在字串使用父目錄的方式進行目錄跨越:

http://example.org/index.php?username=../admin/users

上面URL的運行結果如下:

<?php

include '/cache/../admin/users.html';

?>

此時,..意味著/cache的父目錄,也就是根目錄。這樣上面的例子就等價于:

<?php

include '/admin/users.html';

?>

由于所有的文件都會在文件系統的根目錄下,該流程就允許了一個攻擊者能訪問你服務器上所有的.html文件。

在某些平臺上,攻擊者還可以使用一個NULL來終止字符串,例如:

http://example.org/index.php?username=../etc/passwd%00

這樣就成功地繞開了.html文件擴展名的限制。

當然,一味地去通過猜測攻擊者的所有惡意攻擊手段是不可能的,無論你在文件上加上多少控制,也不能排除風險。重要的是在動態包含時永遠不要使用被污染數據。攻擊手段不是一成不變的,但漏洞不會變化。只要通過過濾數據即可修復這個漏洞(見第一章):

<?php

$clean = array();

/* $_GET[’filename’] is filtered and stored in $clean[’filename’]. */

include '/path/to/{$clean[’filename’]}';

?>

如果你確認參數中只有文件名部分而沒有路徑信息時,另一個有效的技巧是通過使用basename( )來進行數據的過濾:

<?php

$clean = array();

if (basename($_GET[’filename’] == $_GET[’filename’])

{

$clean[’filename’] = $_GET[’filename’];

}

include '/path/to/{$clean[’filename’]}';

?>

如果你允許有路徑信息但想要在檢測前把它化簡,你可以使用realpath()函數:

<?php

$filename = realpath('/path/to/{$_GET[’filename’]}');

?>

通過上面程序處理得到的結果($filename)可以被用來確認是否位于/path/to目錄下:

<?php

$pathinfo = pathinfo($filename);

if ($pathinfo[’dirname’] == ’/path/to’)

{

/* $filename is within /path/to */.

}

?>

如果檢測不通過,你就應該把這個請求記錄到攻擊日志以備后查。這個在你把這個流程作為深度防范措施時特別重要,因為你要確定其它的安全手段失效的原因。

標簽: PHP
相關文章:
主站蜘蛛池模板: seba51久久精品 | 亚洲六月丁香色婷婷综合久久 | 久久er国产精品免费观看8 | 欧美视频日韩视频 | 91在线老王精品免费播放 | 成人性视频在线 | 国产欧美视频一区二区三区 | 亚洲一区二区三区中文字幕5566 | 欧美精品亚洲二区 | 欧美综合在线观看 | 国产精品久久久久不卡绿巨人 | 成人伊人青草久久综合网破解版 | 成人区视频爽爽爽爽爽 | 一级性黄色 | 黄视频国产 | 最新国产精品久久精品 | 国产精品爱久久久久久久9999 | 美女巨胸喷奶水gif放肆吧 | 这里只有精品视频 | 国产精品1024在线永久免费 | 看大片免费一 | 日本xxx片免费高清在线 | 日不卡在线 | 春水堂在线 | 国产h视频在线观看高清 | 色男天堂 | 8mav福利视频在线播放 | 日韩欧美制服 | 成人看的一级毛片 | 国产成人影院一区二区 | 一级欧美在线的视频 | 在线播放亚洲美女视频网站 | 亚洲欲色 | 国产高清免费在线观看 | 日韩精品一区二区三区不卡 | 高清视频黄色录像免费 | 黄色特级一级片 | 成人看片黄a毛片 | 免费国产精品视频 | 日一区二区 | 中国黄色片视频 |