używam tej funkcji, która zawiera kilka fallbacks aby zrekompensować starszymi wersjami PHP, lub po prostu złych wyników:
function getFileMimeType($file) {
if (function_exists('finfo_file')) {
$finfo = finfo_open(FILEINFO_MIME_TYPE);
$type = finfo_file($finfo, $file);
finfo_close($finfo);
} else {
require_once 'upgradephp/ext/mime.php';
$type = mime_content_type($file);
}
if (!$type || in_array($type, array('application/octet-stream', 'text/plain'))) {
$secondOpinion = exec('file -b --mime-type ' . escapeshellarg($file), $foo, $returnCode);
if ($returnCode === 0 && $secondOpinion) {
$type = $secondOpinion;
}
}
if (!$type || in_array($type, array('application/octet-stream', 'text/plain'))) {
require_once 'upgradephp/ext/mime.php';
$exifImageType = exif_imagetype($file);
if ($exifImageType !== false) {
$type = image_type_to_mime_type($exifImageType);
}
}
return $type;
}
Próbuje użyć nowsze funkcje PHP finfo
. Jeśli nie są one dostępne, używa alternatywy mime_content_type
i zawiera zamiennik typu drop-in z biblioteki Upgrade.php, aby upewnić się, że takowa istnieje. Jeśli te nie zwróci nic użytecznego, wypróbuje komendę OS "file
. AFAIK, który jest dostępny tylko w systemach * NIX, możesz go zmienić lub pozbyć się go, jeśli planujesz go użyć w systemie Windows. Jeśli nic nie zadziałało, to próbuje exif_imagetype
jako rezerwę tylko dla obrazów.
Zauważyłem, że różne serwery różnią się znacznie pod względem obsługi funkcji typu MIME, a zamiennik Upgrade.php mime_content_type
jest daleki od ideału. Ograniczone funkcje exif_imagetype
, zarówno oryginalne, jak i uaktualnienie Upgrade.php, działają jednak niezawodnie. Jeśli interesują Cię tylko obrazy, możesz użyć tego ostatniego.
Uzyskiwanie typu MIME pliku w PHP st chory jest dość bolesny w ** ... ;-) –