濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > PHP中危險(xiǎn)的file_put_contents函數(shù)詳解

PHP中危險(xiǎn)的file_put_contents函數(shù)詳解

熱門標(biāo)簽:百度地圖標(biāo)注類型是酒店 商丘外呼系統(tǒng)好處 全國(guó)各省地圖標(biāo)注點(diǎn) 隨州銷售電銷機(jī)器人公司 福建高頻外呼防封系統(tǒng)哪家好 外呼系統(tǒng)人工客服 周口網(wǎng)絡(luò)回?fù)芡夂粝到y(tǒng) 400電話申請(qǐng)辦理 網(wǎng)絡(luò)電話400申請(qǐng)

前言

最近在EIS上遇到一道文件上傳的題,發(fā)現(xiàn)過濾了,這樣基本很多姿勢(shì)都無效了,想了很久沒做出來這題,賽后才知道是利用數(shù)組來繞過, 這里分析了下原理,話不多說了,來一起看看詳細(xì)的介紹吧。

來看下file_put_contents函數(shù)第二個(gè)參數(shù)data的官網(wǎng)定義:

data
要寫入的數(shù)據(jù)。類型可以是 string,array 或者是 stream 資源(如上面所說的那樣)。
 
如果 data 指定為 stream 資源,這里 stream 中所保存的緩存數(shù)據(jù)將被寫入到指定文件中,這種用法就相似于使用 stream_copy_to_stream() 函數(shù)。
 
參數(shù) data 可以是數(shù)組(但不能為多維數(shù)組),這就相當(dāng)于 file_put_contents($filename, join('', $array))。

可以看到,data參數(shù)可以是數(shù)組, 會(huì)自動(dòng)做join('',$array)轉(zhuǎn)換為字符串的

該函數(shù)訪問文件時(shí),遵循以下規(guī)則:

  • 如果設(shè)置了 FILE_USE_INCLUDE_PATH,那么將檢查 *filename* 副本的內(nèi)置路徑
  • 如果文件不存在,將創(chuàng)建一個(gè)文件
  • 打開文件
  • 如果設(shè)置了 LOCK_EX,那么將鎖定文件
  • 如果設(shè)置了 FILE_APPEND,那么將移至文件末尾。否則,將會(huì)清除文件的內(nèi)容
  • 向文件中寫入數(shù)據(jù)
  • 關(guān)閉文件并對(duì)所有文件解鎖
  • 如果成功,該函數(shù)將返回寫入文件中的字符數(shù)。如果失敗,則返回 False。

但我們字符串過濾函數(shù)一般是用preg_match函數(shù)來過濾的,如:

if(preg_match('/\/',$data)){
 die('hack');
}

我們知道,很多處理字符串的函數(shù)如果傳入數(shù)組會(huì)出錯(cuò)返回NULL, 如strcmp,strlen,md5等, 但preg_match 函數(shù)出錯(cuò)返回false, 這里我們可以通過var_dump(preg_match('/\/',$data)); 來驗(yàn)證, 這樣的話,preg_match 的正則過濾就失效了

因此,猜測(cè)文件上傳的代碼是這樣寫的

?php 
 
if(isset($_POST['content'])  isset($_POST['ext'])){
 $data = $_POST['content'];
 $ext = $_POST['ext'];
 
 //var_dump(preg_match('/\/',$data));
 if(preg_match('/\/',$data)){
  die('hack');
 }
 $filename = time();
 file_put_contents($filename.$ext, $data);
}
 
?>

于是我么可以傳入content[]=?php phpinfo();?>ext=php 這樣來繞過

修復(fù)方法

修復(fù)方法是使用fwrite 函數(shù)來代替危險(xiǎn)的file_put_contents函數(shù),fwrite函數(shù)只能傳入字符串,如果是數(shù)組會(huì)出錯(cuò)返回false

?php 
 
if(isset($_POST['content'])  isset($_POST['ext'])){
 $data = $_POST['content'];
 $ext = $_POST['ext'];
 
 //var_dump(preg_match('/\/',$data));
 if(preg_match('/\/',$data)){
  die('hack');
 }
 $filename = time();
 // file_put_contents($filename.$ext, $data);
 $f = fopen($filename.$ext);
 var_dump(fwrite($f,$data));
}
 
?>

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • php file_put_contents()功能函數(shù)(集成了fopen、fwrite、fclose)
  • PHP使用內(nèi)置函數(shù)file_put_contents寫入文件及追加內(nèi)容的方法
  • PHP中fwrite與file_put_contents性能測(cè)試代碼
  • PHP中創(chuàng)建空文件的代碼[file_put_contents vs touch]
  • PHP中file_put_contents追加和換行的實(shí)現(xiàn)方法

標(biāo)簽:佛山 南寧 海南 定西 樂山 六安 十堰 迪慶

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP中危險(xiǎn)的file_put_contents函數(shù)詳解》,本文關(guān)鍵詞  PHP,中,危險(xiǎn),的,file,put,contents,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP中危險(xiǎn)的file_put_contents函數(shù)詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP中危險(xiǎn)的file_put_contents函數(shù)詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    阿坝县| 大新县| 临朐县| 城步| 买车| 宝兴县| 阳西县| 余江县| 永济市| 崇左市| 秦皇岛市| 营山县| 军事| 开封市| 荔波县| 县级市| 清流县| 株洲市| 左权县| 洪江市| 龙陵县| 万州区| 吉隆县| 和田市| 宁武县| 旬邑县| 临城县| 辛集市| 军事| 连南| 沙坪坝区| 宣化县| 拉萨市| 安宁市| 丰城市| 大兴区| 如东县| 平顶山市| 禄丰县| 宾川县| 边坝县|