php远程抓取网站图片并保存

来源:互联网 发布:淘宝48分店铺怎样解封 编辑:程序博客网 时间:2024/04/30 04:42
  1. <?php  
  2.   
  3. /** 
  4.  * 一个用于抓取图片的类 
  5.  * 
  6.  * @package default 
  7.  * @author  WuJunwei 
  8.  */  
  9. class download_image   
  10. {  
  11.       
  12.     public $save_path;                  //抓取图片的保存地址  
  13.   
  14.     //抓取图片的大小限制(单位:字节) 只抓比size比这个限制大的图片  
  15.     public $img_size=0;   
  16.   
  17.     //定义一个静态数组,用于记录曾经抓取过的的超链接地址,避免重复抓取         
  18.     public static $a_url_arr=array();     
  19.       
  20.     /** 
  21.      * @param String $save_path    抓取图片的保存地址 
  22.      * @param Int    $img_size     抓取图片的保存地址 
  23.      */  
  24.     public function __construct($save_path,$img_size)  
  25.     {  
  26.         $this->save_path=$save_path;  
  27.         $this->img_size=$img_size;  
  28.     }  
  29.       
  30.       
  31.     /** 
  32.      * 递归下载抓取首页及其子页面图片的方法  ( recursive 递归) 
  33.      * 
  34.      * @param   String  $capture_url  用于抓取图片的网址 
  35.      *  
  36.      */  
  37.     public function recursive_download_images($capture_url)  
  38.     {  
  39.         if (!in_array($capture_url,self::$a_url_arr))   //没抓取过  
  40.         {                           
  41.             self::$a_url_arr[]=$capture_url;   //计入静态数组  
  42.         } else   //抓取过,直接退出函数  
  43.         {  
  44.             return;  
  45.         }          
  46.           
  47.         $this->download_current_page_images($capture_url);  //下载当前页面的所有图片  
  48.           
  49.         //用@屏蔽掉因为抓取地址无法读取导致的warning错误  
  50.         $content=@file_get_contents($capture_url);   
  51.           
  52.         //匹配a标签href属性中?之前部分的正则  
  53.         $a_pattern = "|<a[^>]+href=['\" ]?([^ '\"?]+)['\" >]|U";     
  54.         preg_match_all($a_pattern$content$a_out, PREG_SET_ORDER);  
  55.           
  56.         $tmp_arr=array();  //定义一个数组,用于存放当前循环下抓取图片的超链接地址  
  57.         foreach ($a_out as $k => $v)   
  58.         {  
  59.             /** 
  60.              * 去除超链接中的 空'','#','/'和重复值   
  61.              * 1: 超链接地址的值 不能等于当前抓取页面的url, 否则会陷入死循环 
  62.              * 2: 超链接为''或'#','/'也是本页面,这样也会陷入死循环,   
  63.              * 3: 有时一个超连接地址在一个网页中会重复出现多次,如果不去除,会对一个子页面进行重复下载) 
  64.              */  
  65.             if ( $v[1] && !in_array($v[1],self::$a_url_arr) &&!in_array($v[1],array('#','/',$capture_url) ) )   
  66.             {  
  67.                 $tmp_arr[]=$v[1];  
  68.             }  
  69.         }  
  70.     
  71.         foreach ($tmp_arr as $k => $v)   
  72.         {              
  73.             //超链接路径地址  
  74.             if ( strpos($v'http://')!==false ) //如果url包含http://,可以直接访问  
  75.             {  
  76.                 $a_url = $v;  
  77.             }else   //否则证明是相对地址, 需要重新拼凑超链接的访问地址  
  78.             {  
  79.                 $domain_url = substr($capture_url, 0,strpos($capture_url'/',8)+1);  
  80.                 $a_url=$domain_url.$v;  
  81.             }  
  82.   
  83.             $this->recursive_download_images($a_url);  
  84.   
  85.         }  
  86.           
  87.     }    
  88.       
  89.         
  90.     /** 
  91.      * 下载当前网页下的所有图片  
  92.      * 
  93.      * @param   String  $capture_url  用于抓取图片的网页地址 
  94.      * @return  Array   当前网页上所有图片img标签url地址的一个数组 
  95.      */  
  96.     public function download_current_page_images($capture_url)  
  97.     {  
  98.         $content=@file_get_contents($capture_url);   //屏蔽warning错误  
  99.   
  100.         //匹配img标签src属性中?之前部分的正则  
  101.         $img_pattern = "|<img[^>]+src=['\" ]?([^ '\"?]+)['\" >]|U";     
  102.         preg_match_all($img_pattern$content$img_out, PREG_SET_ORDER);  
  103.   
  104.         $photo_num = count($img_out);  
  105.         //匹配到的图片数量  
  106.         echo '<h1>'.$capture_url . "共找到 " . $photo_num . " 张图片</h1>";  
  107.         foreach ($img_out as $k => $v)   
  108.         {  
  109.             $this->save_one_img($capture_url,$v[1]);  
  110.         }  
  111.     }  
  112.   
  113.   
  114.     /** 
  115.      * 保存单个图片的方法  
  116.      * 
  117.      * @param String $capture_url   用于抓取图片的网页地址 
  118.      * @param String $img_url       需要保存的图片的url 
  119.      *  
  120.      */  
  121.     public function save_one_img($capture_url,$img_url)  
  122.     {          
  123.         //图片路径地址  
  124.         if ( strpos($img_url'http://')!==false )   
  125.         {  
  126.             // $img_url = $img_url;  
  127.         }else     
  128.         {  
  129.             $domain_url = substr($capture_url, 0,strpos($capture_url'/',8)+1);  
  130.             $img_url=$domain_url.$img_url;  
  131.         }             
  132.         $pathinfo = pathinfo($img_url);    //获取图片路径信息          
  133.         $pic_name=$pathinfo['basename'];   //获取图片的名字  
  134.         if (file_exists($this->save_path.$pic_name))  //如果图片存在,证明已经被抓取过,退出函数  
  135.         {  
  136.             echo $img_url . '<span style="color:red;margin-left:80px">该图片已经抓取过!</span><br/>';   
  137.             return;  
  138.         }                  
  139.         //将图片内容读入一个字符串  
  140.         $img_data = @file_get_contents($img_url);   //屏蔽掉因为图片地址无法读取导致的warning错误  
  141.         if ( strlen($img_data) > $this->img_size )   //下载size比限制大的图片  
  142.         {  
  143.             $img_size = file_put_contents($this->save_path . $pic_name$img_data);  
  144.             if ($img_size)  
  145.             {  
  146.                 echo $img_url . '<span style="color:green;margin-left:80px">图片保存成功!</span><br/>';  
  147.             } else  
  148.             {  
  149.                 echo $img_url . '<span style="color:red;margin-left:80px">图片保存失败!</span><br/>';  
  150.             }  
  151.         } else  
  152.         {  
  153.             echo $img_url . '<span style="color:red;margin-left:80px">图片读取失败!</span><br/>';  
  154.         }   
  155.     }   
  156. // END  
  157.   
  158. set_time_limit(120);     //设置脚本的最大执行时间  根据情况设置   
  159. $download_img=new download_image('E:/images/',0);   //实例化下载图片对象  
  160. $download_img->recursive_download_images('http://www.oschina.net/');      //递归抓取图片方法  
  161. //$download_img->download_current_page_images($_POST['capture_url']);     //只抓取当前页面图片方法  
  162.   
  163. ?> 
0 0
原创粉丝点击