Web三漏洞學習(其二:sql注入)

靶場:NSSCTF 、云曦歷年考核題

二、sql注入

NSSCTF

【SWPUCTF 2021 新生賽】easy_sql

這題雖然之前做過,但為了學習sql,整理一下就再寫一次

打開以后是杰哥的界面

注意到html網頁標題的名稱是? “參數是wllm”

那就傳參數值試一試

首先判斷注入類型數字型字符型

傳1

傳2 沒有回顯

同樣的,后面的3456都沒有回顯

光傳abc也沒有回顯

所以應該是數字型注入

然后判斷閉合方式

接下來傳1'?? (單引號)

出現報錯

然后傳1" ? (雙引號)

頁面又有回顯??

回到報錯的 1'頁面,分析報錯語句

注意看這個位置

這里要記住的是:無論是單引號還是雙引號在sql語句中都是成對出現的,包括 ( ) { } 【】各種括號 。

所以上面的報錯句應該注意到最后的一個引號,要成對則前面必有一個單引號與它成一對。

也就是說,在這個報錯語句中,一對單引號 ' ' 包裹著剛才我們注入的內容:' 1' '

所以這一堆引號就該這么拆:

'?? '? 1'? ' LIMIT 0,1? '

所以包裹著我們注入的 1' 的就是單引號? ' ' 。也就是說明這題的閉合方式是單引號。

既然如此那加個注釋: --+???

目的是把單引號注釋掉

發現頁面沒有報錯了,有了回顯,這就說明閉合方式判斷正確

這里還有一個驗證是否存在sql漏洞的方法:

當輸入1=1時(條件為真),頁面正常顯示或有回顯

?

當輸入1=2時(條件為假),頁面未正常顯示

?這就說明我們輸入的內容數據庫是能夠執行的,即存在sql注入漏洞

那么接下來就是一系列的爆數據庫,直到爆出需要的信息(flag)

正規的講叫先判斷列數

語句是order by

比如現在一列列爆

第一列,有

?第二列有

第三列也有

但是到了第三列就會顯示它不認識了

包括后面的第5列也如此

也就是說,這個數據庫里的表總的只有三列

既然查出了總列數,接下來就需要聯合查詢所有列數下的數據,語句 union select

這里要注意:需要把傳入參數的值1改為-1

然后開始聯合查詢

可以看到用戶名位于第2列的位置,密碼位于第3列的位置 (回顯位為2、3位)

接下來可以看看這兩列的數據,一列列來,第2列:

有了 ,可以看到是test_db

第3列:

都是test_db ,這當然的,兩個都在一個數據庫(test_db)里面

爆出來的這個是數據庫名

接下來查表名(table_name)

然后出現這么個東東

英語也不太好,翻譯一下

ouou? 我知道了,我只改了第2列數據庫名的位置,忘了后面還有個第3列了

大意了haha

加入第3列

提示返回的信息超過一行

一個解決辦法就是使用group_concat把table_name變為一行即可????? group_concat(table_name)

得到有兩個表的表名

接下來查列名(column_name ):

對應的把剛剛的表名table_name改為column_name(列名);

tables改為columns,最后加上剛查到的表名users

執行

select group_concat(column_name) from information_schema.columns where table_schema='test_db' and table_name='users'

得到列名為password

都查出來了,select后面的就全扔掉,看看列名為password的數據列里面有什么,有沒有想要的數據(flag)但這里好像出了點問題,爆出來又是yyy(不對,沒問題,我查的就是password,而password為yyy剛開始就告訴我了),所以問題在于沒有爆出可用的列名

回去找了一下,應該是上一步爆列名的問題,命令

select group_concat(column_name) from information_schema.columns where table_schema='test_db' and table_name='users'

應該改寫為

select group_concat(column_name) from information_schema.columns where table_schema='test_db'

即刪去了后面的and tablename='users'

至于為什么要這么改,后面也想清楚了:

如果查列名的語句含有 and table_name='users'?? 這樣就代表我們是查詢名為users的表下的所有列名;

而如果刪去 and table_name='users'? 僅前面的語句就不指定表名而是查詢所有表下的所有列名,這樣才能把flag列名爆出來? (也就是說其實flag是存在于test_tb表下的,而并不在users表下,如果冒然的將查詢列規定為users表下面,只會畫蛇添足,還找不到flag)

弄清楚以后重新爆列名,不用多此一舉限制查詢的范圍(刪去 and table_name='users')

發現這次列名就全了,可以看到flag列了。

那么接下來直接爆flag

既然剛剛無意中發現flag不在users表下而是在test_tb表下,那就直接爆test_tb表的flag列即可

?

?

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

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

相關文章

單片機非耦合業務邏輯框架

在小型單片機項目開發初期,由于業務邏輯相對簡單,我們往往較少關注程序架構層面的設計。 然而隨著項目經驗的積累,開發者會逐漸意識到模塊間的耦合問題:當功能迭代時,一處修改可能引發連鎖反應。 此時,構…

Zookeeper三臺服務器三節點集群部署(docker-compose方式)

1. 準備工作 - 服務器:3 臺服務器,IP 地址分別為 `10.10.10.11`、`10.10.10.12`、`10.10.10.13`。 - 安裝 Docker:確保每臺服務器已安裝 Docker 和 Docker Compose。 - 網絡通信:確保三臺服務器之間可以通過 IP 地址互相訪問,并開放以下端口: - `2181`:Zookeeper 客戶…

Mac關閉sip方法

Mac關閉sip方法 導航 文章目錄 Mac關閉sip方法導航完整操作流程圖詳細步驟 完整操作流程圖 這東西是我在網上搬運下來的,但是我在為業務實操過程中,根據實操情況還是有新的注意點的 詳細步驟 1.在「關于本機」-「系統報告」-「軟件」;查看SIP是否開啟…

C++| 深入剖析std::list底層實現:鏈表結構與內存管理機制

引言 std::list的底層實現基于雙向鏈表,其設計哲學與std::vector截然不同。本文將深入探討其節點結構、內存分配策略及迭代器實現原理,揭示鏈表的性能優勢和潛在代價。 1. 底層數據結構:雙向鏈表 每個std::list節點包含: 數據域…

漢諾塔問題——用貪心算法解決

目錄 一:起源 二:問題描述 三:規律 三:解決方案 遞歸算法 四:代碼實現 復雜度分析 一:起源 漢諾塔(Tower of Hanoi)問題起源于一個印度的古老傳說。在世界中心貝拿勒斯&#…

【Python】Python 100題 分類入門練習題 - 新手友好

Python 100題 分類入門練習題 - 新手友好篇 - 整合篇 一、數學問題題目1:組合數字題目2:利潤計算題目3:完全平方數題目4:日期天數計算題目11:兔子繁殖問題題目18:數列求和題目19:完數判斷題目21…

【linux】--- 進程概念

進程概念 1.認識馮諾依曼結構2. 操作系統(Operator system)2.1 概念2.2 設計OS的目的2.3 理解操作系統2.4 如何理解管理2.5 理解系統調用和庫函數 3. 進程3.1 基本概念和基本操作3.1.1 描述進程 - PCB3.1.2 task_struct3.1.3 查看進程 3.2 進程狀態3.2.1 運行&&…

算法堆排序記錄

【算法】排序算法之堆排序 - 知乎 應用場景:獲取第n個大或者小的數 操作步驟: 1、將數組構造成堆 2、調整根節點為最大堆 ->倒序對每個根節點執行最大化 ->根節點最大化過程中如果發生交換,需要保證子節點也為最大堆(執行…

STM32 模塊化開發實戰指南:系列介紹

本文是《STM32 模塊化開發實戰指南》系列的導讀篇,旨在介紹整個系列的寫作目的、適用讀者、技術路徑和每一篇的主題規劃。適合從事 STM32、裸機或 RTOS 嵌入式開發的個人開發者、初創工程師或企業項目團隊。 為什么要寫這個系列? 在嵌入式開發中,很多人剛開始都是從點亮一個…

【眼底輔助診斷開放平臺】項目筆記

這是一個標題 任務一前端頁面開發:后端接口配置: 任務二自行部署接入服務 日志修改樣式和解析MD文檔接入服務 Note前端登陸不進去/更改后端api接口304 Not Modifiedlogin.cache.jsonERR_CONNECTION_TIMED_OUT跨域一般提交格式proxy.ts src/coponents 目錄…

【后端開發】Spring MVC-計算器、用戶登錄、留言板

文章目錄 前后端分離設計接口設計思路項目問題解決思路 計算器需求分析接口定義前端頁面代碼服務器代碼 用戶登錄需求分析接口定義用戶登錄校驗接口查詢登錄用戶接口 前端頁面代碼用戶登錄校驗查詢登錄用戶 服務器代碼前后端交互 留言版需求分析接口定義獲取全部留言發布留言前…

在Ubuntu-22.04.5中安裝ONLYOFFICE DocSpace(協作空間)【注意:安裝失敗,謹慎參考!】

1. 通過Docker安裝 預計需要下載10G的鏡像。 (1)下載docspace安裝腳本 curl -fsSL https://download.onlyoffice.com/docspace/docspace-install.sh -o docspace-install.sh (2)修改docker compose的別名為docker-compose ali…

2025年計算機領域重大技術突破與行業動態綜述

——前沿技術重塑未來,開發者如何把握機遇? 2025年第一季度,全球計算機領域迎來多項里程碑式進展,從量子計算到人工智能,從芯片設計到網絡安全,技術革新與產業融合持續加速。本文梳理近三個月內最具影響力…

一、LLM 大語言模型初窺:起源、概念與核心原理

一、初識大模型 1.1 人工智能演進與大模型興起:從A11.0到A12.0的變遷 AI 1.0時代(2012-2022年) 感知智能的突破:以卷積神經網絡(CNN)為核心,AI在圖像識別、語音處理等感知任務中超越人類水平。例如&#…

Redis 分布式鎖+秒殺異步優化

文章目錄 問題思路setnx實現鎖誤刪問題和解決方案Redis Lua腳本問題引出解決方案 setnx實現的問題Redission快速入門redission可重入鎖原理 秒殺優化(異步優化)異步秒殺思路秒殺資格判斷Redis消息隊列 問題 比如我們兩個機器都部署了我們項目,這里nginx使用輪詢的方…

機器學習中的距離度量與優化方法:從曼哈頓距離到梯度下降

目錄 前言一、曼哈頓距離(Manhattan Distance):二、切比雪夫距離 (Chebyshev Distance):三、 閔可夫斯基距離(Minkowski Distance):小結四、余弦距離(Cosine Distance)五、杰卡德距離(Jaccard Distance)六、交叉驗證方法6.1 HoldOut Cross-v…

HTML 嵌入標簽對比:小眾(<embed>、<object>) 與 <iframe> 的優缺點及使用場景和方式

需求背景 在網頁開發中&#xff0c;嵌入外部資源預覽&#xff08;如視頻、PDF、地圖或其他網頁&#xff09;是常見的需求。HTML 提供了多種標簽來實現這一功能&#xff0c;其中 <embed>、<object> 和 <iframe> 是最常用的三種。本文將對比它們的優缺點&…

未來七軸機器人會占據主流?深度解析具身智能方向當前六軸機器人和七軸機器人的區別,七軸力控機器人發展會加快嗎?

六軸機器人和七軸機器人在設計、功能和應用場景上存在明顯區別。六軸機器人是工業機器人的傳統架構&#xff0c;而七軸機器人則在多自由度和靈活性方面進行了增強。 本文將在理解這兩者的區別以及為何六軸機器人仍然是市場主流&#xff0c;從多個方面進行深入解讀六軸和七軸區…

C++基礎精講-07

文章目錄 1. const對象2. 指向對象的指針3. 對象數組4. c中const常見用法總結4.1 修飾常量4.2 修飾指針4.3 修飾函數參數4.4 修飾函數返回值4.5 修飾成員函數4.6 const對象 5. 賦值運算符函數&#xff08;補充&#xff09;5.1 概念5.2 默認賦值運算符函數局限5.3 解決辦法 1. c…

軟件測試之接口測試用例設計

1.接口測試用例設計簡介 我們對系統的需求分析完成之后&#xff0c;即可設計對應的接口測試用例&#xff0c;然后用接口測試用例進行接口測試。接口測試用例的設計也需要用到黑盒測試方法&#xff0c;其與功能測試用例設計的方法類似&#xff0c;接口測試用例設計中還需要增加…