>백엔드 개발 >PHP 튜토리얼 >php脚本下载的图片打不开

php脚本下载的图片打不开

WBOY
WBOY원래의
2016-06-06 20:51:041371검색

<?php /**
 * 抓取远程图片
 *
 * @param string $url 远程图片路径
 * @param string $filename 本地存储文件名
 */
function grabImage($url, $filename = '') {
    if($url == '') {
        return false; //如果 $url 为空则返回 false;
    }
    $ext_name = strrchr($url, '.'); //获取图片的扩展名
    if($ext_name != '.gif' && $ext_name != '.jpg' && $ext_name != '.bmp' && $ext_name != '.png') {
        return false; //格式不在允许的范围
    }
    if($filename == '') {
        $filename = time().$ext_name; //以时间戳另起名
    }
    //开始捕获
    ob_start();
    readfile($url);
    $img_data = ob_get_contents();
    ob_end_clean();
    $size = strlen($img_data);
    $local_file = fopen($filename , 'a');
    fwrite($local_file, $img_data);
    fclose($local_file);
    return $filename;
}
echo	grabImage("http://t1.baidu.com/it/u=1504295979,283866738&fm=52&gp=0.jpg");
?>

上述的代码感觉没有问题,别人也测试过,但是我下载下来,图片文件为什么打不开,蛋疼,坐等贵人解救!

回复内容:

<?php /**
 * 抓取远程图片
 *
 * @param string $url 远程图片路径
 * @param string $filename 本地存储文件名
 */
function grabImage($url, $filename = '') {
    if($url == '') {
        return false; //如果 $url 为空则返回 false;
    }
    $ext_name = strrchr($url, '.'); //获取图片的扩展名
    if($ext_name != '.gif' && $ext_name != '.jpg' && $ext_name != '.bmp' && $ext_name != '.png') {
        return false; //格式不在允许的范围
    }
    if($filename == '') {
        $filename = time().$ext_name; //以时间戳另起名
    }
    //开始捕获
    ob_start();
    readfile($url);
    $img_data = ob_get_contents();
    ob_end_clean();
    $size = strlen($img_data);
    $local_file = fopen($filename , 'a');
    fwrite($local_file, $img_data);
    fclose($local_file);
    return $filename;
}
echo	grabImage("http://t1.baidu.com/it/u=1504295979,283866738&fm=52&gp=0.jpg");
?>

上述的代码感觉没有问题,别人也测试过,但是我下载下来,图片文件为什么打不开,蛋疼,坐等贵人解救!

url错误了。这种写法要抓取静态路径图片。
并且http://t1.baidu.com/it/u=1504295979,2... 也不是个图片地址。或者是有访问限制的地址,本地直接访问无权限。
你可以打印$image_data变量看看

一个对的有访问权限的路径就无问题了。
grabImage("http://s.segmentfault.com/img/logo.pn...);

请使用curl函数进行获取,因为当某些网站采取防外联的时候需要考虑到,比如百度图片。

于是有以下函数:

function getImage($uri,$from){
ob_start();
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $uri);
if($from){
    curl_setopt($ch,CURLOPT_REFERER, $from);
}				
curl_exec($ch);
$img = ob_get_contents();
curl_close($ch);
ob_clean();
return $img;
}

调用:

$uri = "http://imgsrc.baidu.com/forum/pic/item/e55f70600c338744d0fbf8bd510fd9f9d62aa0b4.jpg";
$from = "http://tieba.baidu.com/i/28295132"; //这里请自行分析规律,一般情况分析HEADER中Referer

echo getImage($uri,$from);

若要保存为本地文件请使用二进制写入,如:

$fs = fopen("abc.jpg","w+");
fwrite($fs,getImage($uri,$from));
fclose($fs);

以上就是采集图片和采集防盗链图片的基本方法咯。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.