zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    1.配置pytorch环境
    排序算法总结
    树的存储
    递归回溯法求N皇后问题
    输出分割的字符串
    文件的操作
    Okhttp进行文件的下载
    Android客户端OkHttp的使用以及tomcat服务器的解析客户端发过来的数据
    java集合框架
    spring mvc框架入门
  • 原文地址:https://www.cnblogs.com/pawn-i/p/12094314.html
Copyright © 2011-2022 走看看