好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PHP中危險的file_put_contents函數詳解

PHP中危險的file_put_contents函數詳解

熱門標簽:百度地圖標注類型是酒店 商丘外呼系統好處 全國各省地圖標注點 隨州銷售電銷機器人公司 福建高頻外呼防封系統哪家好 外呼系統人工客服 周口網絡回撥外呼系統 400電話申請辦理 網絡電話400申請

前言

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

來看下file_put_contents函數第二個參數data的官網定義:

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

可以看到,data參數可以是數組, 會自動做join('',$array)轉換為字符串的

該函數訪問文件時,遵循以下規則:

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

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

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

我們知道,很多處理字符串的函數如果傳入數組會出錯返回NULL, 如strcmp,strlen,md5等, 但preg_match 函數出錯返回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 這樣來繞過

修復方法

修復方法是使用fwrite 函數來代替危險的file_put_contents函數,fwrite函數只能傳入字符串,如果是數組會出錯返回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));
}
 
?>

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

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

標簽:佛山 南寧 海南 定西 樂山 六安 十堰 迪慶

巨人網絡通訊聲明:本文標題《PHP中危險的file_put_contents函數詳解》,本文關鍵詞  PHP,中,危險,的,file,put,contents,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP中危險的file_put_contents函數詳解》相關的同類信息!
  • 本頁收集關于PHP中危險的file_put_contents函數詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 麻豆精品秘?国产传媒视频| 国产一级视频免费| 国产在线bd**| 狂野av人人澡人人添巨大| 久久久久久久一精品| 三叶草欧洲码和亚洲码怎么换算| 亚洲综合五月天激动情网| 国产人体精品无码亚洲欧美| 2024最新韩国r级理论片| 天天躁日日躁狠狠躁| 女十八毛片| 色情久久爽爽久免费| 美女直播全婐网站免费免登录| 国产大学生真实在线播放| 成人a毛片免费视频观看| 操女人的逼逼| wwww黄色| 国产网红主播精品无码一区| 韩国三级《偷妻》| chinaspanking调教| 女人毛片| 啊好爽用力| 五级黄18以上免费看网站 - 百度| 纲手被扒开腿做?同人漫画免费| 免费古装一级婬片潘金莲| 黄漫?18禁漫画app| 黄色a级免费网站| 护士囗交10p| 韩国激情合集无删减在线播放| 女性催春最快的药| 亚洲无线码一区国产欧美国日产| 欧美老妇BBBwBBB老太湖北| 欧美黑人喷潮水xxxx| 亚洲高清日韩精品第一区| 60分钟上色床大片免费视频| 口述我和熟妇邻居的性事(1)| 韩国三级中文字幕hd| 日本三级理论片| 美女视频91| 国产肉体ⅩXXX137大胆图片| 夜夜嗨AV人妻蜜臀AV人委|