PHP超全局变量和可变变量

PHP超全局变量

在php中预定义了九大超级全局变量,它们在一个脚本的全部作用域中都可用。这意味着我们不用进行特殊的说明,就可以在函数及类中使用。

  • $GLOBALS : 一个包含了全部变量的全局组合数组。变量的名字就是数组的键
  • $_SERVER : 一个包含了头信息、路径、脚本位置等信息的数组
  • $_GET : 用于收集提交 HTML 表单,传参方式为 get 的表单数据
  • $_POST : 同样收集提交 HTML 表单,但是传参方式为 post
  • $_REQUEST : 具有 get 和 post 二者的功能。
  • $_FILES : 用于文件的接收处理
  • $_COOKIE : 用于获取与setCookie()中的name 值
  • $_SESSION : 用于存储有关用户会话的信息,或更改用户会话的设置
  • $_ENV : 是一个包含服务器端环境变量的数组,可以在PHP 程序的任何地方直接访问它

PHP可变变量

所谓可变变量就是一个变量以另外一个变量的值作为变量名

可变变量是php中的一个特殊变量,在其他语言中也是十分少见。鄙人也是第一次见到这种类型的变量,还是太菜了 /(ㄒoㄒ)/~~

使用下面的代码来可能会更清楚

例子
可以看到 $$b 输出的结果为 123,从而能够解释变量a以变量b的值作为变量名

CTF

了解超全局变量和可变变量之后,再来看一道php代码审计的CTF

题目:

<?php  

error_reporting(0);
include "flag1.php";
highlight_file(__file__);
if(isset($_GET['args'])){
    $args = $_GET['args'];
    if(!preg_match("/^\w+$/",$args)){
        die("args error!");
    }
    eval("var_dump($$args);");
}
?> 

首先正则表达式匹配都是字母的字符串,之后使用eval()执行输出可变变量args的命令
所以我们就要给 $$args 赋值一个变量名,那么就要用到PHP的九大超全局变量

poc
将args赋值为$GLOBALS超全局变量,就会输出包含全部变量的数组,从而出现flag

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

矜庄寂寥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值