piwigo v2.9.5的5個sql注入分別是怎樣的
0x0 專案介紹
專案網址:https://github.com/Piwigo/Piwigo
專案介紹:piwigo是用於網路的開源照相館軟體.專為組織,團隊和個人管理您的照片庫而設計。
官網網址:piwigo.org
0x1 準備工作
Linux下下載https://github.com/Piwigo/Piwigo/archive/ 2.9.5.zip解壓縮、賦權、進入目錄後使用docker安裝:
docker run -d --name piwigo_mysql -e MYSQL_DATABASE=piwigo -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 docker run -d -p 3000:80 -v $(pwd)/:/var/www/html/ --link piwigo_mysql:mysql --name piwigo nimmis/apache-php5
即可看到啟動介面
0x2 稽核
#一admin/group_perm.php中selection和parent參數存在的注入:
#selection值未經驗證進入move_categories函數中
追蹤move_categories函數可以看到函數把該值分解後直接存取到sql語句中
#測試下即可發現漏洞存在
二admin/group_list.php中group_selection參數存在的sql注入:
圖中可以看到group_selection值放入$groups中,selectAction值被放入到$action裡
程式碼中$action對應多個動作,但在多個動作裡$group都被直接黏結到sql語句中,這兒我舉delete方法看下:
這兒很直觀看到被放進了sql語句中,試驗下
三admin/user_perm.php中cat_false參數存在的sql注入:
圖中可以看到cat_false被放入到函數中,
我們追蹤下這個函數,在admin/include/functions.php中找到函數,$cat_false值變成$category經過判斷是否是數組判斷數量後被放入get_uppercat_ids函數中處理,
繼續追蹤get_uppercat_ids函數,上述存在漏洞的參數變成$cat_ids,圖中可以看到該$cat_ids經過簡單判斷被放入sql語句並開始查詢,
這種漏洞函數跳轉比較多,且沒有明顯的看到回顯地方,這種場合特別適合時間注入,我們使用
1 and if(ascii(substr(database(),1,1))>97,1,sleep(5))
驗證可以發現網頁開啟時間延遲,證明漏洞存在,使用sqlmap跑一波
##perm.php存在的sql漏洞:
這個漏洞跟上面三種admin/user_perm.php漏洞相同,呼叫的同一個函數,只是使用者和群組的差別,看張入口圖意思一下:
我們看具體程式碼:
###當post包中存在'filter_category_use'鍵時將'filter_category'值給xx['category']###############往下走,找到xx[' category']被呼叫的地方,可以看到該值未被過濾直接被放到sql語句中。 ###要注意的是這個請求連結在網頁中並未找到,需要手工在post包中加入filter_category_use=on&filter_category=1
sqlmap跑一下
以上是piwigo v2.9.5的5個sql注入分別是怎樣的的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

HQL和SQL在Hibernate框架中進行比較:HQL(1.物件導向語法,2.資料庫無關的查詢,3.類型安全),而SQL直接操作資料庫(1.與資料庫無關的標準,2.可執行複雜查詢和資料操作)。

《OracleSQL中除法運算的用法》在OracleSQL中,除法運算是常見的數學運算之一。在資料查詢和處理過程中,除法運算可以幫助我們計算欄位之間的比例或得出特定數值的邏輯關係。本文將介紹OracleSQL中除法運算的用法,並提供具體的程式碼範例。一、OracleSQL中除法運算的兩種方式在OracleSQL中,除法運算可以用兩種不同的方式來進行

Oracle和DB2是兩個常用的關聯式資料庫管理系統,它們都有自己獨特的SQL語法和特性。本文將針對Oracle和DB2的SQL語法進行比較與區別,並提供具體的程式碼範例。資料庫連接在Oracle中,使用以下語句連接資料庫:CONNECTusername/password@database而在DB2中,連接資料庫的語句如下:CONNECTTOdataba

MyBatis動態SQL標籤解讀:Set標籤用法詳解MyBatis是一個優秀的持久層框架,它提供了豐富的動態SQL標籤,可以靈活地建構資料庫操作語句。其中,Set標籤是用來產生UPDATE語句中SET子句的標籤,在更新作業中非常常用。本文將詳細解讀MyBatis中Set標籤的用法,以及透過具體的程式碼範例來示範其功能。什麼是Set標籤Set標籤用於MyBati

SQL中的Identity是什麼,需要具體程式碼範例在SQL中,Identity是一種用於產生自增數字的特殊資料類型,它常用於唯一識別表中的每一行資料。 Identity欄位通常與主鍵列搭配使用,可確保每筆記錄都有獨一無二的識別碼。本文將詳細介紹Identity的使用方式以及一些實際的程式碼範例。 Identity的基本使用方式在建立表格時,可以使用Identit

在Springboot+Mybatis-plus不使用SQL語句進行多表添加操作我所遇到的問題準備工作在測試環境下模擬思維分解一下:創建出一個帶有參數的BrandDTO對像模擬對後台傳遞參數我所遇到的問題我們都知道,在我們使用Mybatis-plus中進行多表操作是極其困難的,如果你不使用Mybatis-plus-join這一類的工具,你只能去配置對應的Mapper.xml文件,配置又臭又長的ResultMap,然後再寫對應的sql語句,這種方法雖然看上去很麻煩,但具有很高的靈活性,可以讓我們

解決方法:1、檢查登入使用者是否具有足夠的權限來存取或操作該資料庫,確保該使用者俱有正確的權限;2、檢查SQL Server服務的帳戶是否具有存取指定檔案或資料夾的權限,確保該帳戶具有足夠的權限來讀取和寫入該文件或資料夾;3、檢查指定的資料庫文件是否已被其他進程打開或鎖定,嘗試關閉或釋放該文件,並重新運行查詢;4、嘗試以管理員身份運行Management Studio等等。

如何使用SQL語句在MySQL中進行資料聚合和統計?在進行資料分析和統計時,資料聚合和統計是非常重要的步驟。 MySQL作為一個功能強大的關聯式資料庫管理系統,提供了豐富的聚合和統計函數,可以很方便地進行資料聚合和統計操作。本文將介紹使用SQL語句在MySQL中進行資料聚合和統計的方法,並提供具體的程式碼範例。一、使用COUNT函數進行計數COUNT函數是最常用
