【SQL注入】延時盲注

sleep(n)??: 核心延時函數。使數據庫程序暫停?n秒。

??if(condition, true_expr, false_expr)??: 條件判斷函數。如果?condition為真,執行?true_expr,否則執行?false_expr。??用于將延時與判斷條件綁定??。

??mid(a, b, c)??: 字符串截取函數。從字符串?a的第?b位開始,截取?c個字符長度的子串。

通過觀察網頁響應時間是否延遲了5秒,從而判斷出數據庫名字的第一個字母不是 'g',這里返回5,不是g

??substr(a, b, c)??: 功能同?mid(a, b, c),字符串截取函數。

?left(a, b)??: 字符串截取函數。從字符串?a的??左側??截取前?b

database()??: 返回當前數據庫的名稱。

length(a)??: 返回字符串?a的長度。

攻擊原理:

通過組合上述函數,構造一個條件判斷(如?if(ascii(substr(database(),1,1))=100, sleep(5), 0)),如果條件為真,則觸發延時,從而根據頁面的響應時間來判斷猜測的數據是否正確。這是一種“盲注”手段,在無法直接看到查詢結果時使用。

如果當前數據庫名的第一個字母是 't',那么就讓數據庫睡眠0秒(不延遲);否則,就睡眠5秒(產生明顯延遲)。

?id=1 and sleep(if(mid(database(),1,1)='t',0,5))

在SQL注入過程中,推薦使用ASCII碼進行判斷。???

1.防止引號轉義??:可以避免因單引號?'或雙引號?"被應用程序轉義或過濾而導致的注入失敗,提高攻擊的成功率和可靠性。

2.方便工具使用??:為后續使用sqlmap等自動化注入工具提供便利,這些工具通常采用ASCII碼值進行盲注判斷,手動測試時采用同樣方法可以保持一致。

從當前數據庫中查詢第一張表的表名,并取出其第一個字符。如果這個字符的ASCII碼等于116(即字符't'),那么就讓數據庫睡眠2秒;否則,就不睡眠。

select * from t1 where id=1 and if(ascii(substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1,1))=116,sleep(2),0);

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

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

相關文章

IntelliJ IDEA 2025.1 Java Stream Debugger 快速使用指南

1. 功能概覽 Java Stream Debugger 提供 Trace Current Stream Chain 功能,用來在調試時分析和可視化 Stream 操作鏈。 主要用途: 在運行時查看流操作鏈的每一步輸出找出 map/filter 等操作的問題避免手動加 peek() 打印調試2. 使用入口 在 IDEA 2025.1 …

ARM-指令集全解析:從基礎到高階應用

一、ARM 指令集體系結構版本ARM 公司定義了多個指令集版本:ARMv1:原型機 ARM1,沒有用于商業產品。ARMv2:擴展 V1,包含 32 位乘法指令和協處理器指令。ARMv3:第一個微處理器 ARM6 核心,支持 Cach…

第3講 機器學習入門指南

近年來,隨著企業和個人生成的數據量呈指數級增長,機器學習已成為日益重要的技術領域。從自動駕駛汽車到流媒體平臺的個性化推薦,機器學習算法已廣泛應用于各個場景。讓我們深入解析機器學習的核心要義。3.1 機器學習定義機器學習是人工智能的…

深入理解跳表:多層索引加速查找的經典實現

跳表(Skip List)是一種多層有序鏈表結構,通過引入多級索引加速查找,其核心設計類似于“立體高速公路系統”,底層是原始鏈表,上面有各種高度的"高架橋"。 高層道路跨度大,連接遠方節點…

Flutter 視頻播放器——flick_video_player 介紹與使用

在移動端應用中,視頻播放是一個常見的功能場景,例如短視頻、直播、課程、廣告展示等。 Flutter 本身并沒有直接提供視頻播放器組件,而是依賴第三方庫來實現。 今天要介紹的庫是 flick_video_player,它基于 video_player 封裝&…

編寫cmakelists文件常用語句

cmake_minimum_required (VERSION 3.10) 指定最小版本project(XXXX) 指定項目名字 ---------------set(MAIN_EXEC_NAME dwarf_parser) 定義變量${ MAIN_EXEC_NAME } 變量取值set(CMAKE_CXX_STANDARD 14) 指定c14標準,還有11、17、20等標準…

麒麟桌面系統找不到mbr啟動,并重新安裝grub

根據你提供的情況,“麒麟桌面系統找不到MBR啟動”,這通常是由于GRUB引導損壞、MBR記錄丟失或分區表異常導致的。你可以按照以下步驟重新安裝GRUB并修復MBR啟動: ? 步驟一:準備工具 使用銀河麒麟LiveCD或U盤啟動盤(可用Ventoy制作); 啟動電腦,選擇從U盤或光盤進入Live環…

【音頻字幕】構建一個離線視頻字幕生成系統:使用 WhisperX 和 Faster-Whisper 的 Python 實現

一、背景介紹 對于一端沒有字幕外國視頻、字幕,在不懂外語的情況下,怎么獲取相關內容?作為技術宅,怎么自建搭建一個語音轉文字的環境當前AI技術這么發達? 試試 二、系統設計 音頻提取(僅僅是視頻需要該邏輯、本身就是音…

Linux ALSA架構:PCM_OPEN流程 (二)

一 應用端源碼路徑: external\tinyalsa\pcm.c external\tinyalsa\pcm_hw.cstruct pcm *pcm_open(unsigned int card, unsigned int device,unsigned int flags, struct pcm_config *config) {...pcm->ops &hw_ops;pcm->fd pcm->ops->open(card, device,…

tp5的tbmember表閉包查詢 openid=‘abc‘ 并且(wx_unionid=null或者wx_unionid=‘‘)

閉包查詢 tbmember表閉包查詢查詢 openid‘abc并且islose0并且islogout0并且(wx_unionidnull或者wx_unionid’) Db::table(tbmember)->where([openid>abc,islose>0,islogout>0])->where(function ($query){$query->where(wx_unioni…

邪修實戰系列(3)

1、第一階段邪修實戰總覽(9.1-9.30) 把第一階段(基礎夯實期)的學習計劃拆解成極具操作性的每日行動方案。這個計劃充分利用我“在職學習”的特殊優勢,強調“用輸出倒逼輸入”,確保每一分鐘的學習都直接服務…

【GD32】ROM Bootloader、自定義Bootloader區別

Bootloader是應用程序跑起來之前,用于初始化的一段程序,它分為兩種,ROM Bootloader、自定義Bootloader。GD32芯片出廠時預燒錄在ROM中的Bootloader(以下簡稱ROM Bootloader)和自己編寫的Bootloader(以下簡稱…

Linux防火墻-Firewalld

一、 概述 按表現形式劃分: 軟件防火墻: 集成在系統內部,Linux系統: iptables、firewalld、ufw; windows系統下: windows defender 硬件防火墻: 華為防火墻、思科防火墻、奇安信防火墻、深信服防…

【Qt】PyQt、原生QT、PySide6三者的多方面比較

目錄 引言 一、基本定義 二、核心對比維度 1. 編程語言與開發效率 2. 功能與 API 兼容性 3. 性能表現 4. 許可證與商業使用 5. 社區與文檔支持 三、遷移與兼容性 四、適用場景推薦 五、總結對比表 總結 引言 PySide6、PyQt(通常指 PyQt5/PyQt6&#xf…

JavaWeb站內信系統 - 技術設計文檔

1. 系統概述1.1 項目背景本系統旨在為企業或社區平臺提供一套完整的站內信解決方案,支持用戶之間的消息發送、接收、管理等功能,提升用戶間的溝通效率。1.2 設計目標實現用戶間消息發送和接收支持一對一和一對多消息發送提供消息狀態跟蹤(已讀…

Java基礎 9.10

1.System類常見方法和案例exit:退出當前程序arraycopy:復制數組元素,比較適合底層調用,一般使用 Arrays.copyOf 完成復制數組int[] src{1,2,3};int[] dest new int[3]; System.arraycopy(src, 0, dest, 0, 3);currentTimeMilens&…

詳解flink性能優化

1. 簡介 Apache Flink是一個強大的流處理框架,其性能很大程度上取決于內存的使用效率。在大規模數據處理場景中,合理的內存配置和優化可以顯著提升Flink作業的性能和穩定性。本文將深入探討Flink內存優化的各個方面,包括狀態后端選擇、內存配…

VueFlow的箭頭怎么調整

正好最近用到了VueFlow組件,發現箭頭默認樣式太小,無法體現流程展示,因此翻閱相關資料得出下列方法,有什么更好的方法,大家可以推薦推薦,謝謝。方法1:通過邊(Edge)的樣式…

【Python】S1 基礎篇 P9 文件處理與異常處理技術

目錄文件讀取操作讀取文件的全部內容相對路徑和絕對路徑逐行訪問文件內容文件寫入操作寫入單行內容寫入多行內容結構化數據的存儲異常處理機制理解異常的工作原理ZeroDivisionError異常示例try-except語句塊的使用else語句塊的正確使用靜默失敗的合理應用本文將深入探討Python中…

分布式事務實戰手冊:從四場業務災難看方案選型與落地陷阱

在分布式系統的穩定性戰役中,數據一致性問題如同潛伏的暗礁。某生鮮電商因分布式事務設計缺陷,在春節促銷期間出現"下單成功但無庫存發貨"的悖論,3小時內產生2300筆無效訂單,客服投訴量激增300%;某銀行轉賬系…