-PHP 應用文件上傳函數缺陷條件競爭二次渲染黑白名單JS 繞過

#學習前必讀:
1 、課前一定要明白:
無文件解析安全問題上,格式解析是一對一的(不能 jpg 解析 php
換句話來說有解析錯誤配置或后綴解析漏洞時才能實現格式差異解析
2 、文件上傳安全指的是攻擊者通過利用上傳實現后門的寫入連接后門進行權限控制的安
全問題,對于如何確保這類安全問題,一般會從原生態功能中的文件內容,文件后綴,文
件類型等方面判斷,但是漏洞可能不僅在本身的代碼驗證邏輯中出現安全問題,也會在語
言版本,語言函數,中間件,引用的第三方編輯器等存在缺陷地方配合利用。另外文件上
傳也有多個存儲邏輯,不同的文件存儲方案也會給攻擊者帶來不一樣的挑戰!
# 測試環境安裝參考:
https://github.com/ffffffff0x/f8x
https://github.com/fuzzdb-project/fuzzdb
https://github.com/sqlsec/upload-labs-docker
0 、下載上述資源
1 docker 安裝
f8x -d f8x -docker
2 、進入項目文件夾
cd upload-labs-docker
3 、一鍵部署運行
docker-compose up -d
#upload-labs-docker 知識點:
1 、前端 JS
如何判斷是否是前端驗證呢?
首先抓包監聽,如果上傳文件的時候還沒有抓取到數據包,但是瀏覽器就提示文件類型不
正確的話,那么這個多半就是前端校驗了
2 .htaccess
AddType application/x-httpd-php .png(將png類型解析成php類型)
先上傳.htaccess 在上傳png類型
3 MIME 類型
Content-Type image/png
4 、文件頭判斷
GIF89a
5 、黑名單 - 過濾不嚴(大小寫 雙寫php? 00截斷(魔術開關要關 版本小于5.34)? ?PHP5之類)
6.條件競爭
先上傳 后判斷邏輯(就是在文件上傳一剎那 訪問)
7.二次渲染
如果放大圖片 還要圖片清晰 就會進行二次渲染 這就會改動代碼? 使用010editor?
8.函數缺陷
對于move_upload_file 函數 上傳文件用shell.php/.就能上傳

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

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

相關文章

C++的模板(十四):更多的自動內存管理

在前文《C的模板(八):子系統》class DMM,給出了一個自動動態內存管理的例子。https://blog.csdn.net/aaasssdddd96/article/details/139921880 它使用了一個list容器,把兩個類型兼容的指針存放在一起。在new的時候,隨即就把得到的…

Windows下VSCode的安裝

前言 VSCode的安裝看起來平平無奇,但也不是輕輕松松的。筆者將最新的Windows下安裝VSCode,以及運行最簡單的C程序的過程記錄下來,供后續的自己和大家參考。 一、官網下載安裝包 Visual Studio Code - Code Editing. Redefined 二、安裝 直接…

Matlab教程004:Matlab矩陣的拼接重構重排以及矩陣的運算

文章目錄 1.4.3 矩陣的拼接重構重排1.4.3.1 橫向拼接1.4.3.2 縱向拼接1.4.3.3 矩陣的重構重排 1.4.4 矩陣的運算1.4.4.1 算數運算1.4.4.2 矩陣加減1.4.4.3 矩陣乘法1.4.4.4 矩陣轉置 1.4.3 矩陣的拼接重構重排 1.4.3.1 橫向拼接 A和B的行數相同,那么使用[A,B]、[A …

Python小練習系列 Vol.3:生成有效括號組合(回溯 + DFS)

🧠 Python小練習系列 Vol.3:生成有效括號組合(回溯 DFS) 👋 本期我們來刷一道 LeetCode 熱門經典題,借此掌握回溯算法的精髓 —— 生成有效括號組合,是學習遞歸 & DFS 的黃金題型&#xff…

實戰經驗深度解析 | 博睿數據制造行業精選案例集發布!

近年來,我國制造業加速邁向高端化、智能化、綠色化,為經濟高質量發展注入新動能。放眼全球,制造業正加速數字化、智能化轉型,5G、人工智能、邊緣計算等技術與生產全流程深度融合,有力推動柔性化生產與產業鏈協同創新發…

[創業之路-344]:戰略的本質是選擇、聚焦, 是成本/效率/低毛利優先,還是差易化/效益/高毛利優先?無論是成本優先,還是差易化戰略,產品聚焦是前提。

前言: 一、戰略的本質是選擇、聚焦 關于戰略的本質,觸及了商業競爭的核心矛盾:選擇成本優先(效率/低毛利)還是差異化(效益/高毛利),本質上是對企業戰略方向的終極拷問。 1、戰略選…

項目代碼第10講【數據庫運維知識——如何優化數據庫查詢效率?】:各種日志查看;主從復制;分庫分表(MyCat);讀寫分離;區別數據分區、分表、分庫

01. 運維-課程介紹_嗶哩嗶哩_bilibili 一、各種日志查看 二、主從復制 三、分庫分表(MyCat) 四、讀寫分離 五、區別數據分區、分表、分庫 1、數據庫分區 上圖中的ibd文件,是分區表的數據文件,可以分布在不同的物理設備上&…

OpenCV圖像拼接(10)用于實現圖像拼接過程中的時間流逝(timelapse)效果的一個類cv::detail::Timelapser

操作系統:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 編程語言:C11 算法描述 cv::detail::Timelapser 是 OpenCV 庫中用于實現圖像拼接過程中的時間流逝(timelapse)效果的一個類。它通常用于將一系列…

Transformer 通關秘籍2:利用 BERT 將文本 token 化

前面兩節分別通過兩個代碼示例展示了模型將文本轉換為 token 之后是什么樣的,希望你可以對此有一個感性的認識。 本節來簡要介紹一下將一個連續的文本轉換為 token 序列的大致過程,這個過程被稱為分詞,也叫 tokenization。 在你沒了解這方面…

Optional的stream方法,flatMap, filter應用

Java 8引入的Optional和Stream徹底改變了我們處理空值和集合操作的方式。本文將深入探討如何將二者結合使用,通過四個核心場景提升代碼的健壯性和簡潔性。 一、Optional構成的Stream:空值自動過濾 當處理Optional集合時,我們常需要過濾掉空…

參加李繼剛線下活動啟發:未來提示詞還會存在嗎?

上周六,我參加了李繼剛老師組織的線下活動。 現場干貨滿滿,尤其是關于 AI 時代提示詞的價值、與 AI 溝通的藝術等話題,李老師的分享如同醍醐灌頂,讓我對 AI 人機協作有了更深的理解。 將幾點核心收獲整理出來,與大家…

Python基礎知識第二天:從格式化到流程控制

Python基礎知識第二天:從格式化到流程控制 大家好!今天我們來梳理Python的一些重要基礎知識,包括格式化輸出、輸入函數、運算符以及流程控制語句。 1. 格式化輸出 Python提供了多種格式化輸出的方式: # %d, %f, %s 格式化name &q…

GDB: coredump

前言:一句話如下使用 gdb [exec_file] [core_file] # or gdb -c [core_file] [exec_file] #-c指定轉儲的core文件 gdb -c core.5213 spp_uc_frequent_contact_ol_worker # 進入后輸入bt查看調用棧 bt #顯示所有幀棧 bt 10 #顯示前面10個幀棧(感覺沒啥用) bt …

21_js正則_表單驗證

目錄 正則 一、 正則的概念 二、創建正則方式 2.1 構造函數去創建正則 2.2 字面量去創建正則 2,3 test方法 三、正則修飾符 四、 正則的方法 lastIndex test方法 exec 五、字符串方法 replace match search split 六、正則表達式的構成 元字符-- 定位符 元字…

礦山自動化監測解決方案

1.行業現狀 為貫徹落實《中共中央國務院關于推進安全生產領域改革發展的意見》《“十四五”礦山安全生產規劃》(應急〔2022〕64號)、《國務院安委會辦公室關于加強礦山安全生產工作的緊急通知》(安委辦〔2021〕3號)等有關工作部署…

企業級知識庫建設:自建與開源產品集成的全景解析 —— 產品經理、CTO 與 CDO 的深度對話

文章目錄 一、引言二、主流產品與方案對比表三、自建方案 vs. 開源產品集成:技術路徑對比3.1 自建方案3.2 開源產品集成方案 四、結論與個人觀點 一、引言 在當今數據驅動的商業環境中,構建高質量的知識庫已成為企業數字化轉型的關鍵一環。本博客分別從…

【藍橋杯】單片機設計與開發,溫度傳感器DS18B20

一、溫度傳感器概述 結構圖 二、通信過程 三、onewire單總線協議概述 四、單總線的工作原理 黑粗線是單片機發送的,淺的是s18b20回應的 五、溫度傳感器的應用 六、onewire 七、課后習題

Python 在Word中查找并替換文本

在操作Word文檔時,如果想要修正一處反復出現的拼寫錯誤,統一文中前后不一致的術語,或者將文檔中所有的舊聯系方式更新為新號碼。這時我們可以使用 Word中的查找替換功能,快速定位并批量處理文檔中的特定文本,提升編輯效…

Python 筆記 (二)

Python Note 2 1. Python 慢的原因2. 三個元素3. 標準數據類型4. 字符串5. 比較大小: 富比較方法 rich comparison6. 數據容器 (支持*混裝* )一、允許重復類 (list、tuple、str)二、不允許重復類 (set、dict)1、集合(set)2、字典(dict)3、特殊: 雙端隊列 deque 三、數據容器的共…

kill子進程后再wait可以嗎?

在父進程中先使用 kill 函數終止子進程,之后再使用 wait 函數是可行的,下面從原理、使用示例、注意事項幾個方面詳細說明。 原理 kill 函數:其作用是向指定進程發送信號。當向子進程發送 SIGTERM(通常用于請求進程正常終止&…