我正在使用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