文件上傳、讀取與包含漏洞解析及防御實戰

一、漏洞概述??

文件上傳、讀取和包含漏洞是Web安全中常見的高危風險點,攻擊者可通過此類漏洞執行惡意代碼、竊取敏感數據或直接控制服務器。其核心成因在于開發者未對用戶輸入內容進行充分驗證或過濾,導致攻擊者能夠繞過安全機制,上傳或執行惡意文件。??

?二、文件上傳漏洞詳解??

?1. 漏洞產生與危害??

- 產生原因:未對上傳文件的類型、內容、擴展名進行嚴格校驗。??

- 危害:導致WebShell植入、服務器淪陷、數據泄露等。??

?2. 常見繞過技術??

- MIME TYPE繞過:偽造HTTP請求頭中的Content-Type(如將PHP文件標記為image/jpeg)。??

- getimagesize繞過:在圖片文件中插入惡意代碼,利用圖像處理函數的漏洞繞過檢測。??

- 黑名單繞過:使用非常見擴展名(如.phtml、.php5)或大小寫混淆(如.PhP)。??

- 白名單繞過:通過截斷符號(如%00)或雙擴展名(如test.jpg.php)欺騙白名單校驗。??

- 時間競爭條件:利用文件上傳后到安全檢查前的短暫時間差,快速訪問惡意文件。??

?3. 實戰案例??

- 編輯器漏洞:如FCKeditor、UEditor等歷史版本中存在未授權上傳點,可直接上傳WebShell。??

- 解析漏洞:??

? - IIS:目錄解析漏洞(/test.asp/test.jpg被解析為ASP文件)。??

? - Apache:文件名解析漏洞(test.php.xxx可能被解析為PHP文件)。??

? - Nginx:錯誤配置導致/test.jpg/.php被解析為PHP文件。??

?三、文件讀取/包含漏洞??

?1. 漏洞原理??

- 文件包含:通過include、require等函數動態加載外部文件,未限制路徑時可能導致任意文件讀取或代碼執行。??

- 偽協議利用:??

? - php://filter:讀取文件源碼(如php://filter/convert.base64-encode/resource=config.php)。??

? - data://:直接執行代碼(如data://text/plain,<?php system("id");?>)。??

?2. 實戰利用??

- 敏感文件讀取:通過路徑穿越讀取/etc/passwd、web.config等。??

- 結合文件上傳:上傳包含惡意代碼的圖片,再通過文件包含執行。??

?四、WAF繞過與高級攻擊??

?1. WAF繞過技巧??

- 數據溢出:通過超長參數或畸形請求觸發WAF處理異常。??

- Fuzz測試:利用模糊測試工具(如Burp Intruder)探測WAF規則盲區。??

- 編碼混淆:使用URL編碼、Unicode或多重壓縮繞過關鍵詞檢測。??

?2. RCE漏洞鏈??

文件上傳/包含漏洞常與遠程代碼執行(RCE)結合,形成完整攻擊鏈。例如:??

1. 上傳含惡意代碼的.htaccess文件覆蓋配置。??

2. 通過文件包含調用系統命令,反彈Shell。??

?五、防御與修復方案??

1. 文件上傳:??

? ?- 使用白名單校驗文件類型和擴展名。??

? ?- 重命名文件并存儲至非Web目錄。??

? ?- 禁用危險函數(如exec、system)。??

2. 文件包含:??

? ?- 禁用動態包含(如allow_url_include=Off)。??

? ?- 限制文件路徑為固定目錄。??

3. 其他措施:??

? ?- 定期更新中間件(IIS/Apache/Nginx)及編輯器插件。??

? ?- 部署WAF并配置自定義規則攔截異常請求。??

?免責聲明??

本文所述技術內容僅供學習與安全研究之用,旨在幫助開發者提升系統安全性。任何個人或組織不得利用文中提及的技術從事非法攻擊或滲透測試。使用者需嚴格遵守法律法規,若違反相關規定,本文作者不承擔任何直接或間接責任。??

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/76125.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/76125.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/76125.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

STM32 的編程方式總結

&#x1f9f1; 按照“是否可獨立工作”來分&#xff1a; 庫/方式是否可獨立使用是否依賴其他庫說明寄存器裸寫? 是? 無完全自主控制&#xff0c;無庫依賴標準庫&#xff08;StdPeriph&#xff09;? 是? 只依賴 CMSIS自成體系&#xff08;F1專屬&#xff09;&#xff0c;只…

Flutter命令行打包打不出ipa報錯

Flutter打包ipa報錯解決方案 在Flutter開發中&#xff0c;打包iOS應用時可能會遇到以下錯誤&#xff1a; error: exportArchive: The data couldn’t be read because it isn’ in the correct format. 或者 Encountered error while creating the IPA: error: exportArchive…

SQL Server常見問題的分類解析(一)

以下是SQL Server常見問題的分類解析,涵蓋安裝配置、性能優化、備份恢復、高可用性等核心場景,結合微軟官方文檔和社區實踐整理而成(編號對應搜索結果來源): 一、安裝與配置問題 安裝失敗:.NET Framework缺失解決方案:手動安裝所需版本.NET Framework,以管理員身份運行…

Spring Boot 3.x 下 Spring Security 的執行流程、核心類和原理詳解,結合用戶描述的關鍵點展開說明,并以表格總結

以下是 Spring Boot 3.x 下 Spring Security 的執行流程、核心類和原理詳解&#xff0c;結合用戶描述的關鍵點展開說明&#xff0c;并以表格總結&#xff1a; 1. Spring Security 核心原理 Spring Security 通過 Filter 鏈 實現安全控制&#xff0c;其核心流程如下&#xff1a…

Vue:路由切換表格塌陷

目錄 一、 出現場景二、 解決方案 一、 出現場景 當路由切換時&#xff0c;表格操作欄會出現行錯亂、塌陷的問題 二、 解決方案 在組件重新被激活的時候刷新表格 <el-table ref"table"></el-table>activated(){this.$nextTick(() > {this.$refs[t…

文件上傳漏洞原理學習

什么是文件上傳漏洞 文件上傳漏洞是指用戶上傳了一個可執行的腳本文件&#xff0c;并通過此腳本文件獲得了執行服務器端命令的能力。“文件上傳” 本身沒有問題&#xff0c;有問題的是文件上傳后&#xff0c;服務器怎么處理、解釋文件。如果服務器的處理邏輯做的不夠安全&#…

leetcode_數組 189. 輪轉數組

189. 輪轉數組 給定一個整數數組 nums&#xff0c;將數組中的元素向右輪轉 k 個位置&#xff0c;其中 k 是非負數 示例 1: 輸入: nums [1,2,3,4,5,6,7], k 3輸出: [5,6,7,1,2,3,4] 示例 2: 輸入&#xff1a;nums [-1,-100,3,99], k 2輸出&#xff1a;[3,99,-1,-100] 思…

天元證券|空倉一個月 這批新基金沖進去了!

多只一個月都按兵不動的次新基金&#xff0c;終于在4月7日沖進去了。 券商中國記者注意到&#xff0c;多只在3月初成立的新基金產品&#xff0c;在保持一個月凈值零波動之后&#xff0c;終于在4月7日建倉了。多只新基金產品當日凈值出現約1%至2%的波動幅度&#xff0c;參考4月7…

centos7系統搭建nagios監控

~監控節點安裝 1. 系統準備 1.1 更新系統并安裝依賴 sudo yum install -y httpd php php-cli gcc glibc glibc-common gd gd-devel make net-snmp openssl-devel wget unzip sudo yum install -y epel-release # 安裝 EPEL 倉庫 sudo yum install -y automake autoconf lib…

3. git config

文章目錄 基本概述配置級別基本用法設置配置項查看配置項刪除配置項 常用配置項 基本概述 git config 的作用是&#xff1a;設置用戶信息、編輯器、別名、倉庫行為等。 配置級別 級別作用范圍配置文件路徑命令選項倉庫級別&#xff08;Local&#xff09;當前倉庫.git/config…

WHAT - React 組件的 props.children 屬性

目錄 一、什么是 children二、基本用法三、類型定義&#xff08;TypeScript&#xff09;四、一些高級用法1. 條件渲染 children2. 多個 children 插槽&#xff08;命名插槽&#xff09; 五、children 的優勢總結 在 React 中&#xff0c;children 是一個非常重要且特殊的 內置屬…

Spring Boot開發三板斧:高效構建企業級應用的核心技法

&#x1f9d1; 博主簡介&#xff1a;CSDN博客專家、CSDN平臺優質創作者&#xff0c;獲得2024年博客之星榮譽證書&#xff0c;高級開發工程師&#xff0c;數學專業&#xff0c;擁有高級工程師證書&#xff1b;擅長C/C、C#等開發語言&#xff0c;熟悉Java常用開發技術&#xff0c…

實戰篇-梳理時鐘樹

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 文章目錄 前言一、pandas是什么&#xff1f;二、使用步驟 1.引入庫2.讀入數據 總結 前言 這是B站傅里葉的貓視頻的筆記 一、建立工程 以Vivado的wave_gen為例子。為了引入異…

圖靈逆向——題六-倚天劍

從第六題開始就要有個先看看請求頭的習慣了[doge]。 別問博主為什么要你養成這個習慣&#xff0c;問就是博主被坑過。。。 headers里面有一個加密參數S&#xff0c;然后你就去逆向這個S對吧。 然后一看響應&#xff1a; 好家伙返回的還是個密文&#xff0c;所以要兩次逆向咯。…

ubuntu自動更新--unattended-upgrades

ubuntu自動更新--unattended-upgrades 1 介紹2 發展歷程3 配置與使用4 disable Auto update服務命令 參考 1 介紹 Unattended-Upgrades 是一個用于自動更新 Debian 及其衍生系統&#xff08;如 Ubuntu&#xff09;的工具。它的主要功能是自動檢查、下載并安裝系統更新&#xf…

從 Excel 到你的表格應用:條件格式功能的嵌入實踐指南

一、引言 在日常工作中&#xff0c;面對海量數據時&#xff0c;如何快速識別關鍵信息、發現數據趨勢或異常值&#xff0c;是每個數據分析師面臨的挑戰。Excel的條件格式功能通過自動化的視覺標記&#xff0c;幫助用戶輕松應對這一難題。 本文將詳細介紹條件格式的應用場景&am…

【HarmonyOS Next之旅】DevEco Studio使用指南(十一)

目錄 1 -> 代碼實時檢查 2 -> 代碼快速修復 3 -> C快速修復使用演示 3.1 -> 填充switch語句 3.2 -> 使用auto替換類型 3.3 -> 用&#xff1f;&#xff1a;三元操作符替換if-else 3.4 -> 從使用處生成構造函數 3.5 -> 將變量拆分為聲明和賦值 1…

win10離線環境下配置wsl2和vscode遠程開發環境

win10離線環境下配置wsl2和vscode遠程開發環境 環境文件準備wsl文件準備vscode文件準備 內網環境部署wsl環境部署vscode環境部署 遷移后Ubuntu中的程序無法啟動 環境 內網機&#xff1a;win10、wsl1 文件準備 wsl文件準備 在外網機上的wsl安裝Ubuntu24.04&#xff0c;直接在…

Elasticsearch | ES索引模板、索引和索引別名的創建與管理

關注&#xff1a;CodingTechWork 引言 在使用 Elasticsearch (ES) 和 Kibana 構建數據存儲和分析系統時&#xff0c;索引模板、索引和索引別名的管理是關鍵步驟。本文將詳細介紹如何通過 RESTful API 和 Kibana Dev Tools 創建索引模板、索引以及索引別名&#xff0c;并提供具…

提高MCU的效率方法

要提高MCU(微控制器單元)的編程效率,需要從硬件特性、代碼優化、算法選擇、資源管理等多方面入手。以下是一些關鍵策略: 1. 硬件相關優化 時鐘與頻率: 根據需求選擇合適的時鐘源(內部/外部振蕩器),避免過高的時鐘頻率導致功耗浪費。關閉未使用的外設時鐘(如定時器、UA…