国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > 幫助中心 > 正文

php 遠程包含文件漏洞分析第1/6頁

2024-07-09 22:41:01
字體:
來源:轉載
供稿:網友
幾乎所有的cgi程序都有這樣的 bug,只是具體的表現方式不一樣罷了。

一、涉及到的危險函數〔include(),require()和include_once(),require_once()〕

include() && require()語句:包括并運行指定文件。

這兩種結構除了在如何處理失敗之外完全一樣。include() 產生一個警告而 require() 則導致一個致命錯誤。換句話說,如果你想在遇到丟失文件時停止處理頁面就用 require()。include() 就不是這樣,腳本會繼續運行。
如果"allow_url_fopen"在 PHP 中被激活(默認配置),也可以用 URL(通過 HTTP 或者其它支持的封裝協議)而不是本地文件來指定要被包括的文件。如果目標服務器將目標文件作為 PHP 代碼解釋,則可以用適用于 HTTP GET 的 URL 請求字符串來向被包括的文件傳遞變量。
詳細參考:http://cn.php.net/manual/en/function.include.php

require_once() && include_once()
require_once ()和include_once() 語句在腳本執行期間包括并運行指定文件。此行為和 require() 語句類似,唯一區別是如果該文件中的代碼已經被包括了,則不會再次包括。適用于在腳本執行期間同一個文件有可能被包括超過一次的情況下,你想確保它只被包括一次以避免函數重定義,變量重新賦值等問題。
詳細參考:http://cn.php.net/manual/en/function.require-once.php

二、為什么要包含文件

程序員寫程序的時候,不喜歡干同樣的事情,也不喜歡把同樣的代碼(比如一些公用的函數)寫幾次,于是就把需要公用的代碼寫在一個單獨的文件里面,比如 share.php,而后在其它文件進行包含調用。在php里,我們就是使用上面列舉的那幾個函數來達到這個目的的,它的工作流程:如果你想在 main.php里包含share.php,我將這樣寫include("share.php")就達到目的,然后就可以使用share.php中的函數了,像這個寫死需要包含的文件名稱的自然沒有什么問題,也不會出現漏洞,那么問題到底是出在哪里呢?
有的時候可能不能確定需要包含哪個文件,比如先來看下面這個文件index.php的代碼:
[code]

if ($_GET 123456下一頁閱讀全文
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 都兰县| 宁安市| 澳门| 绥棱县| 荥阳市| 山东省| 株洲市| 乌兰浩特市| 遂宁市| 新巴尔虎右旗| 邻水| 临夏县| 鄂温| 三原县| 宣威市| 桂林市| 师宗县| 准格尔旗| 高雄县| 陆丰市| 台安县| 磴口县| 朔州市| 扶绥县| 雷山县| 长岭县| 扎鲁特旗| 乡宁县| 鄂托克旗| 车致| 怀远县| 冀州市| 临沧市| 临桂县| 阿克苏市| 左云县| 平罗县| 托克托县| 塔河县| 乌兰浩特市| 凉山|