首頁 > 後端開發 > php教程 > 批量下载的图片都是0字节,该怎么解决

批量下载的图片都是0字节,该怎么解决

WBOY
發布: 2016-06-13 13:30:31
原創
1226 人瀏覽過

批量下载的图片都是0字节

PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

--><?php $conn = mysql_connect("127.0.0.1","root","123456") or die("无法连接数据库");
@mysql_query("SET character_set_connection=utf8, character_set_results=utf8, character_set_client=binary",$conn);
mysql_select_db("s517",$conn) or die("无法连接数据库");
global $db;

function getImage($url, $filename="") {
if(!$url) return false;

if(!$filename) {
  $ext=strrchr(strtolower($url),".") ;
  if($ext!=".gif" && $ext!=".jpg" && $ext!=".png") return false;
  $str=explode('/',$url) ;
  $filename=$str[count($str)-1] ;
}

ob_start();
readfile($url);
$img = ob_get_contents();
ob_end_clean();
$fp2=@fopen($filename, "a") ;
fclose($fp2) ;
return $filename;
}

//批量下载

    $result = mysql_query("SELECT itemid, thumb FROM table LIMIT 0 , 300");
    while($row = mysql_fetch_array($result)) {
    getImage($row["thumb"],"");
    echo $row["itemid"]."输出成功";
     }
?>
登入後複製

table里面的thumb是采集的远程图片路径
我用这个函数下载下来的图片都是0字节。

------解决方案--------------------
while太快了,sleep一下
------解决方案--------------------
先去一两张看看有什么,而且你的代码里没有输出 getImage()的结果啊.
PHP code

    $result = mysql_query("SELECT itemid, thumb FROM table LIMIT 0 , 1");
    while($row = mysql_fetch_array($result)) {
    echo getImage($row["thumb"],"")."<br>";
    echo $row["itemid"]."输出成功<br>";
     }
<br><font color="#e78608">------解决方案--------------------</font><br>
直接file_get_content file_put_content <div class="clear">
                 
              
              
        
            </div>
登入後複製
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板