如何在PHP中检查上传的文件类型

2021-12-24 00:00:00 file-upload php

我用这段代码来检查图像的类型,

I used this code to check for the type of images,

$f_type=$_FILES['fupload']['type'];

if ($f_type== "image/gif" OR $f_type== "image/png" OR $f_type== "image/jpeg" OR $f_type== "image/JPEG" OR $f_type== "image/PNG" OR $f_type== "image/GIF")
{
    $error=False;
}
else
{
    $error=True;
}

但有些用户抱怨他们在上传任何类型的图像时出错,而有些用户则没有出错!

but some users complain they get an error while uploading any type of images, while some others don't get any errors!

我想知道这是否能解决问题:

I was wondering if this fixes the problem:

if (mime_content_type($_FILES['fupload']['type']) == "image/gif"){...

有什么意见吗?

推荐答案

永远不要使用 $_FILES..['type'].其中包含的信息根本没有经过验证,它是用户定义的值.自己测试类型.对于图片,exif_imagetype 通常是一个不错的选择选择:

Never use $_FILES..['type']. The information contained in it is not verified at all, it's a user-defined value. Test the type yourself. For images, exif_imagetype is usually a good choice:

$allowedTypes = array(IMAGETYPE_PNG, IMAGETYPE_JPEG, IMAGETYPE_GIF);
$detectedType = exif_imagetype($_FILES['fupload']['tmp_name']);
$error = !in_array($detectedType, $allowedTypes);

或者,finfo 函数 也很棒,如果您的服务器支持它们.

Alternatively, the finfo functions are great, if your server supports them.

相关文章