我正在使用PHP getimagesize()
函數來獲取遠程服務器上圖像的文件類型。更好的方式來獲取遠程文件類型來取代PHP的getimagesize()?
查看getimagesize()
這裏的getimagesize()
這裏的http://php.net/manual/en/function.getimagesize.php的PHP文檔,它說這個函數首先下載整個文件,然後獲取關於該文件的信息。
該評論還提供了替代getimagesize()
聲稱只下載第一個字節,直到它獲得所需的信息比第一個下載整個文件更快的信息。
雖然這個新功能的問題是,它被命名爲getJpegSize($img_loc)
,並聲稱適用於JPEG文件。由於我的用戶顯然不會僅限於JPG文件,因此我很好奇,是否有更好的方法可以做到這一點,但速度會很快,但也適用於其他圖像類型。
新函數的代碼如下。也直接鏈接到PHP文件頁面,註釋和代碼位於:http://php.net/manual/en/function.getimagesize.php#88793
// Retrieve JPEG width and height without downloading/reading entire image.
// From http://php.net/manual/en/function.getimagesize.php
function getJpegSize($img_loc) {
$handle = fopen($img_loc, "rb") or die("Invalid file stream.");
$new_block = NULL;
if(!feof($handle)) {
$new_block = fread($handle, 32);
$i = 0;
if($new_block[$i]=="\xFF" && $new_block[$i+1]=="\xD8" && $new_block[$i+2]=="\xFF" && $new_block[$i+3]=="\xE0") {
$i += 4;
if($new_block[$i+2]=="\x4A" && $new_block[$i+3]=="\x46" && $new_block[$i+4]=="\x49" && $new_block[$i+5]=="\x46" && $new_block[$i+6]=="\x00") {
// Read block size and skip ahead to begin cycling through blocks in search of SOF marker
$block_size = unpack("H*", $new_block[$i] . $new_block[$i+1]);
$block_size = hexdec($block_size[1]);
while(!feof($handle)) {
$i += $block_size;
$new_block .= fread($handle, $block_size);
if($new_block[$i]=="\xFF") {
// New block detected, check for SOF marker
$sof_marker = array("\xC0", "\xC1", "\xC2", "\xC3", "\xC5", "\xC6", "\xC7", "\xC8", "\xC9", "\xCA", "\xCB", "\xCD", "\xCE", "\xCF");
if(in_array($new_block[$i+1], $sof_marker)) {
// SOF marker detected. Width and height information is contained in bytes 4-7 after this byte.
$size_data = $new_block[$i+2] . $new_block[$i+3] . $new_block[$i+4] . $new_block[$i+5] . $new_block[$i+6] . $new_block[$i+7] . $new_block[$i+8];
$unpacked = unpack("H*", $size_data);
$unpacked = $unpacked[1];
$height = hexdec($unpacked[6] . $unpacked[7] . $unpacked[8] . $unpacked[9]);
$width = hexdec($unpacked[10] . $unpacked[11] . $unpacked[12] . $unpacked[13]);
return array($width, $height);
} else {
// Skip block marker and read block size
$i += 2;
$block_size = unpack("H*", $new_block[$i] . $new_block[$i+1]);
$block_size = hexdec($block_size[1]);
}
} else {
return FALSE;
}
}
}
}
}
return FALSE;
}
您打算如何處理您稱爲「文件類型」的信息?既然你說你想避免下載整個資源,這是否意味着你永遠不會真的下載它?那麼,實際上重要的是遠程服務器與數據一起發送的MIME類型信息;如果是這樣,請改爲創建HEAD請求,並評估「Content-Type」標頭的內容。 – CBroe