Heim >Backend-Entwicklung >PHP-Tutorial >php 如何高效获取远程图片信息?

php 如何高效获取远程图片信息?

WBOY
WBOYOriginal
2016-07-06 13:52:491609Durchsuche

<code><?php set_time_limit(0);
$imageArray = [
        'http://ww2.sinaimg.cn/mw690/63918611gw1f51fiawmcrj208s0aeq4a.jpg',
        'http://ww3.sinaimg.cn/large/797a354agw1f4ya2a91tqj20k00zk765.jpg',
        'https://ss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/img/logo/bd_logo1_31bdc765.png',
        'https://pic1.zhimg.com/d32d2194fac9dec7215e5581ca0fdc24_r.jpg',
    ];
echo date('Y-m-d H:i:s') . substr((string) microtime(), 1, 6), "\r\n";
foreach ($imageArray as $imageUrl) {
    $imageSize[] = @getimagesize($imageUrl);
    echo date('Y-m-d H:i:s') . substr((string) microtime(), 1, 6), "\r\n";
}
var_dump($imageSize);
</code></code>

如下,我有一个页面,要展示图片信息,但getimagesize时间太长了,有其他高效的方法吗?
我是获取图片信息,不是查看存不存在

回复内容:

<code><?php set_time_limit(0);
$imageArray = [
        'http://ww2.sinaimg.cn/mw690/63918611gw1f51fiawmcrj208s0aeq4a.jpg',
        'http://ww3.sinaimg.cn/large/797a354agw1f4ya2a91tqj20k00zk765.jpg',
        'https://ss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/img/logo/bd_logo1_31bdc765.png',
        'https://pic1.zhimg.com/d32d2194fac9dec7215e5581ca0fdc24_r.jpg',
    ];
echo date('Y-m-d H:i:s') . substr((string) microtime(), 1, 6), "\r\n";
foreach ($imageArray as $imageUrl) {
    $imageSize[] = @getimagesize($imageUrl);
    echo date('Y-m-d H:i:s') . substr((string) microtime(), 1, 6), "\r\n";
}
var_dump($imageSize);
</code></code>

如下,我有一个页面,要展示图片信息,但getimagesize时间太长了,有其他高效的方法吗?
我是获取图片信息,不是查看存不存在

问题是这样的。这个事情给PHP做绝对是个坑。
流量上来了,图片源站不稳定了,网络出问题了,分分钟搞死服务器。

可以问前端大神有没有方案,或折中办法。

如果没有的话,可以在数据库建个表,维护一份图片信息数据。

然后当有图片加入的时候,就先判断表是否有数据了,如果没有获取图片的大小信息存入表,然后再做后面操作。

页面显示的时候直接查出来。

这里不说缓存,不说队列,不说图片本地化(而不是使用他站图片),是因为看起来这些会大大增加复杂度,当有必要的时候再考虑。

V2站上不是有大神已经提出解决方案了吗?
http://v2ex.com/t/286977#reply17

getImageInfo 试试
getimagesize时间太长,可能是因为你带宽太低,或者是图片服务器响应速度慢导致的

抄了条评论
getimagesize

As noted below, getimagesize will download the entire image before it checks for the requested information. This is extremely slow on large images that are accessed remotely. Since the width/height is in the first few bytes of the file, there is no need to download the entire file. I wrote a function to get the size of a JPEG by streaming bytes until the proper data is found to report the width and height:

<code class="php"><?php // Retrieve JPEG width and height without downloading/reading entire image.
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;
}
?></code>
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn