24、文件上傳漏洞——Apache文件解析漏洞

文章目錄

  • 一、環境簡介
  • 一、Apache與php三種結合方法
  • 二、Apache解析文件的方法
  • 三、Apache解析php的方法
  • 四、漏洞原理
  • 五、修復方法

一、環境簡介

??Apache文件解析漏洞與用戶配置有密切關系。嚴格來說,屬于用戶配置問題,這里使用ubantu的docker來復現漏洞:

apt-get install apache2
apt-get install php7.0
apt-get install libapache2-mod-php7.0

一、Apache與php三種結合方法

  • CGI:共同網關接口,是HTTP服務器與機器上其他程序進行通信的一個接口,讓web服務器必要時啟動額外的程序處理動態內容。
  • FastCGI:CGI解釋器的更快實現,可以提供良好的性能、伸縮性等。
  • Module:php作為apache的模塊,也是用的最多的一種方法。

Apache文件解析漏洞就發生在Module結合方法上。

查看apache和php的結合方法:
在這里插入圖片描述

二、Apache解析文件的方法

一個重要文件/etc/mime.types
在這里插入圖片描述
??這里記錄了大量的文件后綴和mime類型,當客戶端請求一個文件時,如果后綴在這個列表里,那么apache一方面返回對應的content-type給瀏覽器,一方面根據文件的MIME類型進行下一步處理。如果不在列表,apache不會返回content-type給瀏覽器,而是直接返回文件內容,由瀏覽器自動處理。

cat /etc/mime.types | grep php
在這里插入圖片描述

這里注釋掉關于php的全部項。例如對于第一項后綴名為php/pht/phtml的文件,apache將會將其給php處理器進行解析。

三、Apache解析php的方法

/etc/apache2/mods-enabled/php7.2.conf
在這里插入圖片描述

  • apache通過/etc/mime.types識別文件所屬mime類型,然后根據MIME類型,apache將文件交給對應的程序進行處理。
  • apache或者通過/etc/apache2/mods-enabled/php7.2.conf進行文件匹配,用SetHandler設置請求處理程序。
    如上圖,如果(php|php3|php5|php7|pht|phtml)是請求文件的最后一個后綴,則把文件交給php處理器(php_module)來處理,處理完之后把結果返回給apache,再由apache發送給瀏覽器。

四、漏洞原理

??Apache文件解析漏洞設計到一個解析文件的特性:Apache默認一個文件可以有多個以點分割的后綴,當右邊的后綴無法識別(不在mime.types內),則繼續向左識別。例如,當我們請求這樣一個文件:shell.php.xxx.yyy

  • yyy無法被識別,向左;
  • xxx無法被識別,向左;
  • php發現后綴是php,交給php處理這個文件。

如果,apache都不認識,將把文件直接返回給客戶端,也就是爆源碼。

在web目錄下創建一個1.php.aaa的文件,并訪問:
在這里插入圖片描述

可以看到并沒有被解析成php,為什么?
因為apache本身并不存在所謂的解析漏洞。讓我們回顧解析過程:

  • yyy無法被識別,向左;
  • xxx無法被識別,向左;
  • php發現后綴是php,交給php解釋器處理這個文件。

最后這一步雖然交給php解釋器來處理這個文件,但是php解釋器也不認識.aaa的后綴,所以就直接輸出了。

??其實,解析漏洞的產生,是由于運維人員在配置服務器時,為了使apapche服務器能解析php,而自己添加了一個handler,例如:AddHandler application/x-httpd-php .php。它的作用是為了讓apache把文件交給php_module解析,就是說在文件名的任何位置匹配到php后綴,apache都會讓pap_module去解析。

添加一個handler之后,訪問1.php.xxx.yyy的解析流程是這樣:

  • yyy無法被識別,向左;
  • xxx無法被識別,向左;
  • php激活php處理器,執行php代碼。

解析漏洞就產生了。
在這里插入圖片描述

五、修復方法

  1. 不要使用AddHandle,改成SetHandler,寫好正則,就不會有解析問題。
    在這里插入圖片描述
  2. 禁止.php.這樣的文件執行
    在這里插入圖片描述

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

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

相關文章

IOday7作業

1> 使用無名管道完成父子進程間的通信 #include<myhead.h>int main(int argc, const char *argv[]) {//創建存放兩個文件描述符的數組int fd[2];int pid -1;//打開無名管道if(pipe(fd) -1){perror("pipe");return -1;}//創建子進程pid fork();if(pid &g…

wordpress小記

1.插件市場搜索redis&#xff0c;并按照 Redis Object cache插件 2.開啟php的redis擴展 執行php -m|grep redis&#xff0c;沒有顯示就執行 yum -y install php-redis3.再次修改wp配置文件&#xff0c;增加redis的配置 define( WP_REDIS_HOST, 114.80.36.124 );define( WP_…

非標設計之電磁閥

電磁閥&#xff1a; 分類&#xff1a; 動畫演示兩位三通電磁閥&#xff1a; 兩位三通電磁閥動畫演示&#xff1a; 111&#xff1a; 氣缸回路的介紹&#xff1a; 失電狀態&#xff1a; 電磁閥得電狀態&#xff1a; 兩位五通電磁閥的回路&#xff1a;&#xff08;常用&#xf…

算數運算符和算數表達式

基本算數運算符 算數運算符&#xff1a; &#xff08;加法運算符或正值運算符&#xff09;、-&#xff08;減法運算符或負值運算符&#xff09;、*&#xff08;乘&#xff09;、/&#xff08;除&#xff09;、%&#xff08;求余數&#xff09; 雙目運算符&#xff1a; 雙目…

四則運算 .

輸入一個表達式&#xff08;用字符串表示&#xff09;&#xff0c;求這個表達式的值。 保證字符串中的有效字符包括[‘0’-‘9’],‘’,‘-’, ‘*’,‘/’ ,‘(’&#xff0c; ‘)’,‘[’, ‘]’,‘{’ ,‘}’。且表達式一定合法。字符串長度滿足1≤n≤1000 輸入描述&#x…

CGAL的2D符合規定的三角剖分和網格

1、符合規定的三角剖分 1.1、定義 如果三角形的任何面的外接圓在其內部不包含頂點&#xff0c;則該三角形是 Delaunay 三角形。 約束 Delaunay 三角形是一種盡可能接近 Delaunay 的約束三角形。 約束 Delaunay 三角形的任何面的外接圓在其內部不包含從該面可見的數據點。 如果…

陀螺儀LSM6DSV16X與AI集成(3)----讀取融合算法輸出的四元數

陀螺儀LSM6DSV16X與AI集成.2--姿態解算 概述視頻教學樣品申請完整代碼下載使用demo板生成STM32CUBEMX串口配置IIC配置CS和SA0設置串口重定向參考程序初始化SFLP步驟初始化SFLP讀取四元數數據演示 概述 LSM6DSV16X 特性涉及到的是一種低功耗的傳感器融合算法&#xff08;Sensor…

MySQL之創建時間類型的字段表

mysql之創建時間類型的字段表 CREATE TABLE tab(birthday DATE, -- 生日job_time DATETIME, -- 記錄年月日時分秒login_time TIMESTAMP -- 時間戳NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP )解釋&#xff1a; NOT NULL DEFAULT &#xff1a;默認不為空…

css未來:使用light-dark()切換主題色

css未來&#xff1a;使用light-dark()切換主題色 要根據使用的是淺色模式還是深色模式來更改顏色&#xff0c;我們通常會使用 prefers-color-scheme 媒體查詢。為了讓代碼實現變得更容易&#xff0c;CSS 現在附帶了一個名為 light-dark() 的實用函數。該函數接受兩個顏色值作為…

編譯原理lab3-cminus_compiler-LLVM簡要熟悉

lab3實驗報告&#xff0c;我的實驗報告圖例很少&#xff0c;這次只有兩張圖&#xff0c;其余的都以復制輸出的形式展現出來了&#xff0c;最終提交的代碼在最后 [[#你的提交|你的提交]][[#實驗設計|實驗設計]][[#提交一&#xff1a;手動編寫.ll|提交一&#xff1a;手動編寫.ll…

TREK610C高壓放大器

181/2461/8938技術規格 輸出電壓&#xff1a;0到10 kV直流電壓 輸出電流&#xff1a;0到2 mA 轉換率&#xff1a;大于500 V/μs 信號帶寬&#xff1a;直流到1.0 kHz &#xff08;-3dB&#xff09; 放大倍數&#xff1a;1000 V/V 閉環系統以保持低噪音、高精確度電壓輸出 短…

最簡單的基于 FFmpeg 的音頻解碼器

最簡單的基于 FFmpeg 的音頻解碼器 最簡單的基于 FFmpeg 的音頻解碼器正文參考工程文件下載 參考雷霄驊博士的文章&#xff0c;鏈接&#xff1a;最簡單的基于FFMPEGSDL的音頻播放器&#xff1a;拆分-解碼器和播放器 最簡單的基于 FFmpeg 的音頻解碼器 正文 FFmpeg 音頻解碼器…

【ArcGIS微課1000例】0080:ArcGIS將shp轉json(geojson)案例教程

本文以案例的形式,講述在ArcGIS軟件中,將矢量數據轉為GeoJSON的方法。 擴展閱讀:【GIS風暴】GeoJSON數據格式案例全解 文章目錄 一、GeoJson簡介二、ArcGIS將矢量數據轉為GeoJSON一、GeoJson簡介 GeoJSON是一種基于JSON的地理空間數據交換格式,它定義了幾種類型JSON對象以…

Spring Cloud Gateway 網關的基礎使用

1. 什么是網關&#xff1f;網關有什么用&#xff1f; 在微服務架構中&#xff0c;網關就是一個提供統一訪問地址的組件&#xff0c;它解決了內部微服務與外部的交互問題。網關主要負責流量的路由和轉發&#xff0c;將外部請求引到對應的微服務實例上。同時提供身份認證、授權、…

Spring-Boot---配置文件

文章目錄 配置文件的作用配置文件的格式PropertiesProperties基本語法讀取Properties配置文件 ymlyml基本語法讀取yml配置文件 Properties VS Yml 配置文件的作用 整個項目中所有重要的數據都是在配置文件中配置的&#xff0c;具有非常重要的作用。比如&#xff1a; 數據庫的…

230. 二叉搜索樹中第K小的元素 --力扣 --JAVA

題目 給定一個二叉搜索樹的根節點 root &#xff0c;和一個整數 k &#xff0c;請你設計一個算法查找其中第 k 個最小元素&#xff08;從 1 開始計數&#xff09;。 解題思路 利用List存儲數據&#xff1b;遍歷整個樹&#xff0c;讀取數各個節點的value&#xff1b;對value進行…

Python繪制多分類ROC曲線

目錄 1 數據集介紹 1.1 數據集簡介 1.2 數據預處理 2隨機森林分類 2.1 數據加載 2.2 參數尋優 2.3 模型訓練與評估 3 繪制十分類ROC曲線 第一步&#xff0c;計算每個分類的預測結果概率 第二步&#xff0c;畫圖數據準備 第三步&#xff0c;繪制十分類ROC曲線 1 數據集…

【數據結構】——排序篇(上)

前言&#xff1a;前面我們已經學過了許許多多的排序方法&#xff0c;如冒泡排序&#xff0c;選擇排序&#xff0c;堆排序等等&#xff0c;那么我們就來將排序的方法總結一下。 我們的排序方法包括以下幾種&#xff0c;而快速排序和歸并排序我們后面進行詳細的講解。 直接插入…

Qt實現二維碼生成和識別

一、簡介 QZxing開源庫: 生成和識別條碼和二維碼 下載地址&#xff1a;https://gitcode.com/mirrors/ftylitak/qzxing/tree/master 二、編譯與使用 1.下載并解壓&#xff0c;解壓之后如圖所示 2.編譯 打開src目錄下的QZXing.pro&#xff0c;選擇合適的編譯器進行編譯 最后生…

util.js

一、util.js是什么&#xff1f; 1、util.js是Node.js提供的一個工具庫&#xff0c;主要用于輔助實現JavaScript代碼的通用功能。 2、除了Node.js中內置的模塊外&#xff0c;util.js是Node.js中最核心的模塊之一。 3、通過util.js&#xff0c;開發者可以輕松實現JavaScript常…