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

PHP识别文件伪装(文件上传),第1张

概述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识别文件伪装(文件上传)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1009373.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存