php审计1-extract函数变量覆盖

php审计1-extract函数变量覆盖

这是一个关于php审计的栏目,本人也是初学者,分享一下网上的关于php审计的一些知识,学习一下php的语法,顺便记录一下学习过程。

以下是一个关于php审计ctf题

php 复制代码
<?php

$flag='flag.txt'; 
extract($_GET);
 if(isset($shiyan))
 { 
    $content=trim(file_get_contents($flag));
    if($shiyan==$content)
    { 
        echo'ctf{过关}'; 
    }
   else
   { 
    echo'Oh.no';
   } 
   }

?>

分析代码,先了解一下extract函数

定义和用法

extract() 函数从数组中将变量导入到当前的符号表。

该函数使用数组键名作为变量名,使用数组键值作为变量值。针对数组中的每个元素,将在当前符号表中创建对应的一个变量。

该函数返回成功设置的变量数目。

php 复制代码
<?php
$a = "Original";
$my_array = array("a" => "Cat","b" => "Dog", "c" => "Horse");
extract($my_array);
echo "\$a = $a; \$b = $b; \$c = $c";
?>

运行结果如下:

复制代码
$a = Cat; $b = Dog; $c = Horse 

就是将数组my_array对应的键(a,b,c)作为变量,来接收my_array对应的值(cat,Dog,Horse),如果其中的变量之前有赋值过,如a = "Original";,那么运行该函数后,会覆盖之前的值a="Cat"。

file_get_contents(flag)是获取flag中的路径字符串,读取该路径指定的文件内容,这里是读取文件flag.txt里面的内容。

trim函数是去掉字符串前后的空格。

这里的逻辑就是需要我们通过get方式,给变量shiyan赋值,让shiyan的值等于flag.txt里面的内容,这样才能通关。

但是我们并不知道flag.txt里面的值,这个题考的就是我们如何绕过验证过关。

刚才已经分析过,extract()函数可以将之前的变量的值覆盖,$flag虽然已经赋值了,但是程序是从上至下运行的,我们在url上给flag重新赋一个值,这样就覆盖原先的值,绕过验证:

但是给flag重新赋值后,file_get_contents(flag)就无法正常读取数据了,content应为空字符串,$shiyan的值也应为空,payload如下:

复制代码
php?shiyan=&flag=1

或者

复制代码
php?shiyan=&flag=

文件下载:

https://download.csdn.net/download/m0_53073183/90277339

相关推荐
FreeBuf_34 分钟前
微软 SharePoint Server 0Day漏洞遭在野利用
microsoft·php·sharepoint
曼岛_1 小时前
[网络安全] Linux权限维持-隐藏篇
linux·安全·web安全·安全威胁分析
视觉&物联智能1 小时前
【杂谈】-筑牢企业防线:抵御恶意人工智能代理的攻击
人工智能·网络安全·ai·企业安全·agi
JS_SWKJ1 小时前
攻防升级下,网闸与光闸的创新突围——2026年网络安全隔离行业新趋势及产品实践
网络·安全·web安全
齐潇宇2 小时前
LVS 基线检查与安全加固指南(附案例)
服务器·网络·php
亚马逊云开发者2 小时前
Claude Mythos Preview 来了:Anthropic 网络安全专用大模型在 Amazon Bedrock 上开放申请,代码审计要变天了
安全·web安全·状态模式
数字哨兵(和中)2 小时前
9.8 分高危漏洞复现:CVE-2026-27944 Nginx UI 信息泄露漏洞
安全·web安全
爱学习的小囧2 小时前
SXi LAG 链路聚合负载均衡配置全教程 | LACP 协议 + 交换机联动,新手也能落地
运维·服务器·php·负载均衡·esxi
郝学胜-神的一滴2 小时前
[系统设计] 新鲜事系统:写扩散与读扩散的实现与对比
java·设计模式·php·软件构建·需求分析·软件设计·系统设计
C2H5OH13 小时前
PortSwigger SQL注入LAB2
网络安全