私はこの関数を使用しています。これには、古いバージョンの PHP または単に悪い結果を補うためのいくつかのフォールバックが含まれています。
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;
}
新しい PHPfinfo
関数を使用しようとします。それらが利用できない場合は、代替を使用し、 Upgrade.phpライブラリmime_content_type
からのドロップイン置換を含めて、これが存在することを確認します。それらが有用なものを返さなかった場合、OS のコマンドを試します。*NIXシステムでのみ利用可能なAFAIK。これをWindowsで使用する予定がある場合は、これを変更するか、削除することをお勧めします。何も機能しない場合は、画像のみのフォールバックとして試行されます。file
exif_imagetype
私は、サーバーによって MIME タイプ関数のサポートが大きく異なり、Upgrade.php のmime_content_type
置き換えが完全ではないことに気付きました。exif_imagetype
ただし、元の機能と Upgrade.php の置き換えの両方の限定された機能は、かなり確実に機能しています。画像だけに関心がある場合は、この最後の画像のみを使用することをお勧めします。