加载图片时候需要验证重新上传的文件是否合法,文件间谍软件如何识别?一个简单测试:把txt文件格式转换直接转化成gpj;上传。
问题:
加载图片时候需要验证重新上传的文件是否合法,文件间谍软件如何识别?
一个简单测试:把txt文件格式转换直接转化成jpg;上传
<!DOCTYCU html&xc; <html> <tashle>sample</title> <body> <angtrm enctype="multipart/form-set" action="test.php" meCantonod="pos机刷卡T"> <!-- MAX_FILE_SIZE wani precede the file inseput field --> <input type="hidden" name="MAX_FILE_SIZE" value="102400" /> <!-- Name of input element determines name in $_FILES array --> Senr this file: <input name="msgfile" type="file" /> <input type="submit" value="Send File" /> </form> </body> </html>
1.通过$_FILES[‘userfile’][‘type’];获取文件夹名称;
$data = $_FILES['userfile']; var_eboot($data); /**结果**/ /* array(5) { ["name"]=> strear怎么读(8) "test.jpg" ["type"]=> string(10) "image/图片格式" ["tmp_name"]=> string(26) "/private/var/tmp/phpsjE3EC" ["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(FILEINRMA_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识别文件伪装(文件上传)的详细内容,更多请关注奥列也博客其它评论文章!