PHP中危險的file_put_contents函數(shù)詳解
前言
最近在EIS上遇到一道文件上傳的題,發(fā)現(xiàn)過濾了<,這樣基本很多姿勢都無效了,想了很久沒做出來這題,賽后才知道是利用數(shù)組來繞過, 這里分析了下原理,話不多說了,來一起看看詳細的介紹吧。
來看下file_put_contents函數(shù)第二個參數(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ù)組, 會自動做join('',$array)
轉(zhuǎn)換為字符串的
該函數(shù)訪問文件時,遵循以下規(guī)則:
- 如果設(shè)置了 FILE_USE_INCLUDE_PATH,那么將檢查 *filename* 副本的內(nèi)置路徑
- 如果文件不存在,將創(chuàng)建一個文件
- 打開文件
- 如果設(shè)置了 LOCK_EX,那么將鎖定文件
- 如果設(shè)置了 FILE_APPEND,那么將移至文件末尾。否則,將會清除文件的內(nèi)容
- 向文件中寫入數(shù)據(jù)
- 關(guān)閉文件并對所有文件解鎖
- 如果成功,該函數(shù)將返回寫入文件中的字符數(shù)。如果失敗,則返回 False。
但我們字符串過濾函數(shù)一般是用preg_match函數(shù)來過濾的,如:
if(preg_match('/\</',$data)){ die('hack'); }
我們知道,很多處理字符串的函數(shù)如果傳入數(shù)組會出錯返回NULL, 如strcmp,strlen,md5等, 但preg_match 函數(shù)出錯返回false, 這里我們可以通過var_dump(preg_match('/\</',$data));
來驗證, 這樣的話,preg_match 的正則過濾就失效了
因此,猜測文件上傳的代碼是這樣寫的
<?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ù)來代替危險的file_put_contents函數(shù),fwrite函數(shù)只能傳入字符串,如果是數(shù)組會出錯返回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é)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
php獲取網(wǎng)頁標(biāo)題和內(nèi)容函數(shù)(不包含html標(biāo)簽)
有時候我們需要獲取網(wǎng)頁的標(biāo)題與內(nèi)容,就是個采集函數(shù),這里簡單分享下,方便需要的朋友2014-02-02同一空間綁定多個域名而實現(xiàn)訪問不同頁面的PHP代碼
同一空間綁定多個域名而實現(xiàn)訪問不同頁面的PHP代碼...2006-12-12PHP框架Laravel插件Pagination實現(xiàn)自定義分頁
這篇文章主要為大家詳細介紹了PHP框架Laravel5.1插件Pagination實現(xiàn)自定義分頁的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-05-05PHP微信網(wǎng)頁授權(quán)的配置文件操作分析
這篇文章主要介紹了PHP微信網(wǎng)頁授權(quán)的配置文件操作,結(jié)合實例形式分析了php微信授權(quán)配置文件的相關(guān)功能、用法及操作注意事項,需要的朋友可以參考下2019-05-05PHP實現(xiàn)數(shù)組和對象的相互轉(zhuǎn)換操作示例
這篇文章主要介紹了PHP實現(xiàn)數(shù)組和對象的相互轉(zhuǎn)換操作,結(jié)合實例形式分析了php使用get_object_vars以數(shù)組形式訪問對象的方法,以及對象與數(shù)組相互轉(zhuǎn)換操作技巧,需要的朋友可以參考下2019-03-03