您的位置 首页 php

PHP识别文件伪装(文件上传)

问题:

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

一个简单测试:把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)}*/

没有检测出来;

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"}*/

没有检测出来;

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知识,请访问php教程!

以上就是PHP识别文件伪装(文件上传)的详细内容,更多请关注求知技术网其它相关文章!

文章来源:智云一二三科技

文章标题:PHP识别文件伪装(文件上传)

文章地址:https://www.zhihuclub.com/1951.shtml

关于作者: 智云科技

热门文章

发表评论

您的电子邮箱地址不会被公开。

网站地图