• PHP 文件上传之如何识别文件伪装?——PHP的fileinfo扩展可!


    问题:文件上传时候需要验证上传的文件是否合法,文件伪装如何识别?

    一个简单测试:把txt文件后缀直接改成jpg;上传

    <!DOCTYPE html>
    <html>
        <title>test</title>
        <body>
            <form enctype="multipart/form-data" action="test.php" method="POST">
                <!-- MAX_FILE_SIZE must precede the file input field -->
                <input type="hidden" name="MAX_FILE_SIZE" value="102400" />
                <!-- Name of input element determines name in $_FILES array -->
                Send this file: <input name="userfile" type="file" />
                <input type="submit" value="Send File" />
            </form>
        </body>
    </html>
    

     1.通过$_FILES['userfile']['type'];获取文件后缀名;

    $data = $_FILES['userfile'];
    var_dump($data);
    /**结果**/
    /*
    array(5) {
      ["name"]=>
      string(8) "test.jpg"
      ["type"]=>
      string(10) "image/jpeg"
      ["tmp_name"]=>
      string(26) "/private/var/tmp/phpfyE3EC"
      ["error"]=>
      int(0)
      ["size"]=>
      int(19)
    }
    */

    T_T 没有检测出来;

    2.用pathinfo()函数来获取文件路径的信息

    $data = $_FILES['userfile'];
    // var_dump($data);
    var_dump(pathinfo($data['name']));
    
    /**结果**/
    /*
    array(4) {
      ["dirname"]=>
      string(1) "."
      ["basename"]=>
      string(8) "test.jpg"
      ["extension"]=>
      string(3) "jpg"
      ["filename"]=>
      string(4) "test"
    }
    */

    T_T 没有检测出来;

    3.PHP的扩展fileinfo(需要安装开启)

    $data = $_FILES['userfile'];
    $filename = $data['tmp_name'];
    $finfo   = finfo_open(FILEINFO_MIME_TYPE);//返回 mime 类型。 自 PHP 5.3.0 可用。
    $mimetype = finfo_file($finfo, $filename);
    finfo_close($finfo);
    var_dump($mimetype);
    
    /**结果**/
    //string(10) "text/plain"

    ^_^ 可!可!可!监测到文件mime类型并不是一个jpg!

    最后附上PHP手册介绍fileinfo的地址:https://www.php.net/manual/zh/book.fileinfo.php

  • 相关阅读:
    一周见闻速记
    glibc下的内存管理
    流(flow)
    Liunx学习笔记
    逆向工程androidAPK(待补充)
    Ubuntu Linux环境搭建|软件篇
    Ubuntu Linux 源记录
    android 权限
    Android源码下载(ubuntu12.04(amd64))
    游戏外挂编程之神器CE的使用
  • 原文地址:https://www.cnblogs.com/pawn-i/p/12094314.html
Copyright © 2020-2023  润新知