【Web安全】深入淺出理解“SQL注入-偽靜態注入”及空格限制繞過技巧

文章目錄

  • 什么是偽靜態注入?
  • 偽靜態注入中如何繞過空格限制?
    • 1. 用注釋符替代空格
    • 2. 用不可見字符(URL 編碼)替代
    • 3. 用括號分隔語句
    • 4. 用特殊符號替代
  • 核心邏輯

往期文章

【Web安全】一次性搞懂 ReDOS 漏洞原理/檢測/防御
【Web安全】一次性搞懂 XSS 漏洞原理/檢測/防御
【Web安全】一次性搞懂 CSRF 漏洞原理/檢測/防御
【Web安全】一次性搞懂 SSRF 漏洞原理/檢測/防御
【Web安全】一次性搞懂越權漏洞原理/檢測/防御
【Web安全】邏輯漏洞之支付漏洞:原理、場景與防御
【Web安全】小白也能懂的并發漏洞:原理、場景與防御
【Web安全】邏輯漏洞之URL跳轉漏洞:原理、場景與防御

對于剛踏入 Web 安全領域的人來說,SQL 注入是繞不開的重要知識點,而偽靜態注入作為 SQL 注入的特殊場景,常常讓人感到困惑。本文將解析偽靜態注入,并介紹其空格限制的繞過方法。

什么是偽靜態注入?

要理解偽靜態注入,我們得先從 URL 說起。大家平時瀏覽網頁時,可能會注意到兩種不同形式的 URL。

  • 一種是動態網頁的 URL,比如index.php?id=1,這種 URL 里通過?和&清晰地傳遞著參數。
  • 一種則看起來像靜態頁面的 URL,例如index-1.html或者article/123.html,這些就是偽靜態 URL。

偽靜態其實是通過服務器的相關配置,比如 Apache 的 Rewrite、Nginx 的 rewrite 模塊,把動態 URL 偽裝成了靜態頁面的樣子。這樣做的好處是提升了 URL 的美觀度,也對 SEO 更友好。但大家要知道,這種偽裝只是表面上的,URL 里的參數本質上還是動態傳遞的。

而偽靜態注入,就是當網站對偽靜態 URL 中的參數沒有進行嚴格過濾時,攻擊者可以通過構造惡意參數來注入 SQL 語句。比如說,針對index-1.html這個偽靜態 URL,攻擊者可能會構造出index-1' and 1=1--.html這樣的惡意 URL,從而觸發注入。所以,偽靜態注入的核心就在于偽靜態 URL 背后的參數過濾不嚴格,給了攻擊者可乘之機。

偽靜態注入中如何繞過空格限制?

在 SQL 注入里,空格是個非常重要的角色,它像個分隔符,把 SQL 關鍵字、函數、參數等區分開來,比如select * from users where id=1這句話,正是有了空格,數據庫才能正確理解語句的結構。但很多網站會設置過濾規則來攔截空格,比如把空格替換成空,這時候就需要想辦法用其他字符或方式來替代空格,讓 SQL 語句還能被數據庫正確解析。下面就給大家介紹幾種常見的方法。

1. 用注釋符替代空格

數據庫支持的一些注釋符,像/**/-- #,在某些情況下可以替代空格,而且不會影響語句的邏輯。

在 MySQL 中,/**/是很常用的。比如原來的語句select * from users where id=1,可以寫成select/**/*/**/from/**/users/**/where/**/id=1,這樣數據庫依然能正確解析。

舉個偽靜態注入的例子,針對index-1.html這個 URL,注入語句可以改成index-1'/**/and/**/1=1--.html。不過這里要注意,-- 后面需要加個空格,當然也可以用#來替代。

但有一點要提醒大家,在偽靜態注入場景中,如果 URL 被服務器解析為路徑,/**/可能會被當成路徑分隔符,這樣注入就會失效,所以使用的時候要多留意。

2. 用不可見字符(URL 編碼)替代

ASCII 中有一些不可見字符,比如制表符、換行符、回車符,在數據庫中它們會被解析為 “空白分隔符”,我們可以把它們進行 URL 編碼后傳入,以此來繞過空格過濾。

常見的有制表符,它的 URL 編碼是%09,對應著 ASCII 中的 Tab 鍵;換行符的 URL 編碼是%0a;回車符的 URL 編碼是%0d

比如原注入語句是id=1' and 1=1,我們可以寫成id=1'%09and%091=1,這里就是用%09替代了空格。

3. 用括號分隔語句

數據庫允許用括號()來分隔函數、表名、條件等,這在一定程度上可以替代空格的分隔作用,尤其適用于關鍵字與參數的分隔。

比如原來的語句select * from users where id=1,可以寫成select(*)from(users)where(id=1)

在偽靜態注入場景中,針對index-1.html,可以構造出index-1')and(1=1)--.html這樣的注入語句。

4. 用特殊符號替代

部分數據庫還支持一些特定符號作為隱性分隔符。

在 MySQL 中,反引號可以用來包裹表名或列名,間接起到分隔的作用,比如select*fromuserswhereid=1`。

在 SQL Server 等部分環境中,加號+可以被解析為空格,不過需要結合它的 URL 編碼%2b來使用。

核心邏輯

其實,繞過空格限制的本質就是找到數據庫能夠解析為 “分隔符” 的字符或語法,用它們來替代空格的作用,讓注入語句在沒有空格的情況下,依然能被數據庫正確識別和執行。在實際操作中,大家要結合數據庫的類型,像 MySQL、SQL Server、Oracle 等,以及網站的過濾規則,靈活地進行測試,才能找到有效的繞過方法。

本文是「Web安全基礎」系列的第 9 篇,點擊專欄導航查看全部系列內容。

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

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

相關文章

【讀論文】Step-Audio 2 深度解讀:邁向工業級語音交互的「全能型選手」

引言:step-Audio升級 語音交互技術,作為人機交互最自然、最直接的方式之一,正以前所未有的速度發展。從簡單的語音指令到流暢的語音對話,我們對 AI 的期望越來越高。然而,要讓 AI 真正成為我們的“知心伙伴”,僅僅能“聽懂”和“說出”還遠遠不夠。 一個理想的語音 AI,…

java web 重定向

目錄結構 demo\day20\src\com\demo\service\Dome1.javademo\day20\src\com\demo\service\Dome2.javademo\day20\src\com\demo\service\Dome3.javademo\day20\src\com\demo\service\Dome4.javademo\day20\web\WEB-INF\lib\javax.servlet.jardemo\day20\web\index.jspdemo\day20\…

MySQL(配置)——MariaDB使用

一、簡介 MariaDB 和 MySQL 作為兩個流行的關系型數據庫管理系統,它們的區別可以從多個角度來探討。盡管 MariaDB 最初是 MySQL 的一個分支,但隨著時間的推移,它們逐漸在功能、性能和開發方向上有所不同。MariaDB 是 MySQL 的一個分支&#x…

Web3:賽道劃分與發展趨勢解析

區塊鏈技術現在已經從單一的加密貨幣支付系統發展為涵蓋金融、藝術、組織治理和社區文化的多元生態系統。這次我們將深入解析 DeFi(去中心化金融)、NFT(非同質化代幣)、DAO(去中心化自治組織)與 MEME&#…

LeetCode 283 - 移動零

思路 使用雙指針法,一次遍歷完成原地修改。 慢指針 slow:指向下一個非零元素應該被放置的位置。快指針 fast:遍歷整個數組,尋找非零元素。 當 fast 遇到非零數時,將其值賦給 slow 指向的位置,然后 slow 前進…

8. 網絡層

在復雜的網絡環境中確定一個合適的路徑.1. IP協議1. 基本概念IP協議:提供一種能力(有非常大的概率,做到某事),把數據報從主機A,跨網絡,送到主機B --> 必須要有方式,標識通信兩端唯一性!&…

【通識】線性代數(Linear Algebra)

線性代數被廣泛應用于抽象代數和泛函分析中;通過解析幾何,線性代數能被具體表示,線性代數被泛化為算子理論。而非線性模型被近似為線性模型,應用場景多為自然科學和社會科學。 費馬和笛卡爾的工作,線性代數出現于十七世…

Qt 嵌入式界面優化技術

在嵌入式系統中,界面性能直接影響用戶體驗和系統穩定性。由于嵌入式設備通常資源受限(如低性能 CPU、有限內存、小尺寸屏幕),需針對性優化 Qt 界面以實現流暢顯示和高效交互。本文從渲染引擎、資源管理、布局優化到硬件加速&#…

去除視頻字幕 4 : 下一步,打算研究 Video Inpainting (視頻修復):

就是說,到現在,才算是真正開始,才發現真正的問題。 嘗試去除視頻上的字幕,使用 IOPaint, 效果很初級。。。問題描述 請幫我分析此時的效果。 此時的右側字幕區域,閃爍不停!我原本以為效果會很好。實際非常…

代碼隨想錄算法訓練營第五十五天|圖論part5

并查集理論基礎 初始化: void init() {for (int i 0; i < n; i) {father[i] i;} } 尋根&#xff1a; // 并查集里尋根的過程 int find(int u) {return u father[u] ? u : father[u] find(father[u]); // 路徑壓縮 } 判斷u跟v是否同根 // 判斷 u 和 v是否找到同一個根 b…

安卓模擬器 adb Frida hook 抓包

基本步驟 adb connect 127.0.0.1:62001adb forward tcp:27042 tcp:27042 adb forward tcp:27043 tcp:27043adb shell./data/local/tmp/frida-server再開啟cd D:\linuxdir\python\fridapython main.py下載夜神模擬 https://www.yeshen.com/ 安裝adb 點擊下載adb&#xff08…

編程與數學 03-002 計算機網絡 14_網絡性能分析

編程與數學 03-002 計算機網絡 14_網絡性能分析一、網絡性能指標&#xff08;一&#xff09;帶寬、時延、吞吐量等指標的定義與測量方法&#xff08;二&#xff09;性能指標對網絡應用的影響二、網絡性能的測試方法&#xff08;一&#xff09;使用網絡測試工具&#xff08;如Wi…

AT9880B參數特征

AT9880B 是一款高性能北斗單模衛星導航接收機 SOC 單芯片&#xff0c;芯片集成射頻前端和數字基帶、北斗多頻衛星信號處理引擎、電源管理功能。 芯片支持接收中國北斗二號和北斗三號&#xff0c;支持接收 B1I、B1C、B2I、B3I、B2a 和 B2b 等頻點信號。主要特征 支持北斗二號/三…

eBPF 賦能云原生: WizTelemetry 無侵入網絡可觀測實踐

引言 隨著 KubeSphere 企業版 4.2.0 的正式發布&#xff0c;WizTelemetry 可觀測平臺 2.0 也同步亮相。作為本次升級中的重磅模塊之一&#xff0c;它迅速引發了開發與運維團隊的廣泛關注。 本系列文章將系統解讀 WizTelemetry 的核心能力與落地實踐。繼前兩篇介紹了平臺架構與指…

【JAVA安全-Fastjson系列】Fastjson 1.2.24 反序列化漏洞分析及測試環境構建【復習回顧】

Fastjson 1.2.24 反序列化漏洞分析及測試環境構建 漏洞背景 Fastjson 是阿里巴巴開源的一個高性能 Java JSON 庫&#xff0c;廣泛用于 Java 對象的序列化和反序列化。在 1.2.24 及之前的版本中&#xff0c;存在一個嚴重的安全漏洞&#xff0c;攻擊者可以通過構造惡意的 JSON 字…

關于神經網絡CNN的搭建過程以及圖像卷積的實現過程學習

通過如下博客內容學習了CNN搭建的步驟&#xff0c;按照博主的思路完成了cnn網絡的構建并完成50個epoch的訓練并畫出損失函數的曲線圖時有滿滿的成就感 PyTorch深度學習實戰&#xff08;3&#xff09;——使用PyTorch構建神經網絡_pytorch 神經網絡-CSDN博客 通過如下博客內容…

nodejs 實現Excel數據導入數據庫,以及數據庫數據導出excel接口(核心使用了multer和node-xlsx庫)

項目地址&#xff1a;https://gitee.com/LiangDouJun/nodejsExcel 一、實現效果 1、數據庫數據導出 2、excel導入 二、代碼實現 // 根據環境加載對應的配置文件 const env process.env.NODE_ENV || development; require(dotenv).config({ path: .env.${env} });const expr…

VUE2 學習筆記8 v-text/html/cloak/once/pre/自定義

除了之前已經介紹過的v-on v-bind v-for v-if v-show&#xff0c;vue還有很多其他的指令。v-textv-text是Vue內置指令。內置指令&#xff0c;是Vue內部定義好的&#xff0c;開發的時候直接拿來用就行了。v-text用于向其所在的標簽添加文本。<body><div id"root&q…

vue 使用postcss-pxtorem 實現適老化

1. 安裝依賴 npm install postcss-pxtorem -D2. 配置 Vite (vite.config.js) import { defineConfig } from vite import vue from vitejs/plugin-vue import postcsspxtorem from postcss-pxtoremexport default defineConfig({plugins: [vue()],css: {postcss: {plugins: [po…

Rust:高效錯誤處理工具 anyhow

Rust 的 anyhow 庫是一個專注于簡化錯誤處理的工具&#xff0c;特別適合應用程序開發場景。它通過統一的錯誤類型和便捷的 API&#xff0c;減少模板代碼&#xff0c;提升錯誤信息的可讀性。以下是其核心用法及示例&#xff1a;1. 安裝與基礎用法 在 Cargo.toml 中添加依賴&…