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这里就是一个引用,在前面加个&符号就好

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

代码如下:

复制代码
<?php


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

​

希望本文能够帮助大家。

相关推荐
DK1858383225212 小时前
知识付费会员小程序/付费圈子系统——课程兑换码+会员体系完整实战,开源运营级方案
小程序·uni-app·开源·php
江上清风山间明月13 小时前
Nginx基于域名区分的多网站部署
运维·nginx·部署·php·多个网站
工业甲酰苯胺16 小时前
Redis--集群搭建与主从复制原理
数据库·redis·php
JSON_L18 小时前
FastAdmin 短信插件开发完整教程
php·fastadmin
卡次卡次118 小时前
14.2:详细补充:子进程会复制什么
前端·python·php
万法若空19 小时前
Nmap 完全使用指南:从入门到精通
安全·web安全
晓梦林20 小时前
Loooower靶场学习笔记
笔记·学习·安全·web安全
txg66620 小时前
网络安全领域简报(2026年5月1日~5月8日)
网络·安全·web安全
梦梦代码精21 小时前
Likeshop一个开源商城到底有哪些功能模块?
java·低代码·开源·php
赏金术士1 天前
Kotlin 从入门到进阶 之协程 Flow 模块(九)
开发语言·kotlin·php