当前位置: 首页 > news >正文

[CISCN2021 Quals]upload(PNG-IDAT块嵌入马)

<?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("传都没有传上去");
    }
}

检查文件是不是图片,然后还要求宽高需要是1,上传的文件名被 urldecode解码以后检查是否有 c、i、h、ph 这些字符
文件名 mb_strtolower 转成小写保存

然后就是 example.php,可以通过扫目录发现

<?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);
    }
}

解压文件,然后检查了一下文件是不是 zip 结尾,然后解压图片到 临时目录

后面开始遍历这个目录找图片,重新计算了图片的大小,然后又重新写到了一个新的文件中,又删掉了旧的图片

所以在图片末尾添加的马是不会被重新写入新的文件中,必须把马嵌到图片数据中

所以我们的思路就是上传一个嵌有马的图片的压缩包,然后被解压,重新写入新的文件

压缩文件名需要是 zip 结尾,但是上传的地方限制了 i 字符,查文档发现可以使用 Unicode 绕过

php文档

在这里插入图片描述

下面也有例子,拉丁文里,大写的 I 上面有个点,小写的 I 上面没有点,可以这样绕过检测 i

在这里插入图片描述

可以测试一下

<?php

$name = "ab.z%c4%b0p";

var_dump(mb_strtolower('İ')==='i');

$fileName=urldecode($name);
if(stristr($fileName,"i")) {
  die("有些东西让你传上去的话那可不得了");
}
echo "image/" . mb_strtolower($fileName);
# bool(true) 
# image/ab.zip

嵌入马到图片数据中,可以使用这个工具

PNG-IDAT-Payload-Generator

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

修改后要保证长度不变,然后复制出来,替换回去

在这里插入图片描述
在这里插入图片描述

重新生成马

在这里插入图片描述
在这里插入图片描述

然后就可以压缩包上传了,但是这里会检查getimagesize 有没有图片的宽高等一些属性

可以添加 #define width 1 #define height 1 绕过检查

在这里插入图片描述

解压,执行,在 /etc 目录下发现 flag

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

相关文章:

  • 计算机408看不懂?那是你还不知道这套学习方法和资源
  • 2022国赛C:古代玻璃制品的成分分析与鉴别
  • 【云原生】springcloud12——服务网关Gateway
  • 快速掌握Zookeeper及Java API
  • numpy对数组进行过滤并获取下标
  • AttributeError: ‘HTMLParser‘ object has no attribute ‘unescape‘解决方案
  • 自定义类型:结构体(内存对齐),枚举,联合
  • 【云原生之Docker实战】使用Docker部署Wizard文档管理系统
  • 图书管理系统的设计与实现/ssm的图书管理网站
  • 深度学习pytorch训练代码模板(个人习惯)
  • 盒模型(非要让我凑满五个字标题)
  • OPTEE:TA和TA加载(一)
  • 抽象之美——万物皆可设计
  • steam搬砖项目,2022年详细讲解具体操作流程
  • c语言进阶:指针的进阶(下)
  • JavaScript-如何实现克隆(clone)函数
  • 【笔记】你不知道的JS读书笔记——Promise
  • CSS3 变换
  • express如何解决request entity too large问题
  • HTTP 简介
  • IIS 10 PHP CGI 设置 PHP_INI_SCAN_DIR
  • JavaScript HTML DOM
  • Java比较器对数组,集合排序
  • Java教程_软件开发基础
  • php中curl和soap方式请求服务超时问题
  • SpriteKit 技巧之添加背景图片
  • Sublime text 3 3103 注册码
  • 工作中总结前端开发流程--vue项目
  • 今年的LC3大会没了?
  • 前端面试之闭包
  • 协程
  • 学习Vue.js的五个小例子
  • 一起来学SpringBoot | 第三篇:SpringBoot日志配置
  • 云大使推广中的常见热门问题
  • NLPIR智能语义技术让大数据挖掘更简单
  • ​一帧图像的Android之旅 :应用的首个绘制请求
  • # 数论-逆元
  • (02)Cartographer源码无死角解析-(03) 新数据运行与地图保存、加载地图启动仅定位模式
  • (delphi11最新学习资料) Object Pascal 学习笔记---第7章第3节(封装和窗体)
  • (ZT)北大教授朱青生给学生的一封信:大学,更是一个科学的保证
  • (搬运以学习)flask 上下文的实现
  • (附程序)AD采集中的10种经典软件滤波程序优缺点分析
  • (附源码)ssm基于web技术的医务志愿者管理系统 毕业设计 100910
  • (一) springboot详细介绍
  • (已解决)vue+element-ui实现个人中心,仿照原神
  • (转)ObjectiveC 深浅拷贝学习
  • (转)创业的注意事项
  • (转)从零实现3D图像引擎:(8)参数化直线与3D平面函数库
  • .NET/C# 的字符串暂存池
  • .NET处理HTTP请求
  • .net专家(高海东的专栏)
  • .php结尾的域名,【php】php正则截取url中域名后的内容
  • .pings勒索病毒的威胁:如何应对.pings勒索病毒的突袭?
  • @manytomany 保存后数据被删除_[Windows] 数据恢复软件RStudio v8.14.179675 便携特别版...
  • [AIGC] Redis基础命令集详细介绍