在前期的php教程就讲了php ,但是那只是下载了一张图片,原理是一样的,要想下载一个网页的所有图片只要使用正则表达式进行判断,找出所有的图片url就可以进行循环下载了,我特地参照网络资源编写了gd库图片下载类!
php代码如下:
<?phpheader("content-type:text/html ; chart=utf-8");if (!empty($_post['submit'])){ $url = $_post['url']; //为了获取相对路径的图片所做的操作 $url_fields = par_url($url); $main_url = $url_fields['host']; $ba_url = substr($url,0,strrpos($url, '/')+1); //获取网页内容 //设置代理服务器 $opts = array('http'=>array('request_fulluri'=>true)); $conte建筑学专业就业前景xt = stream_context_create($opts); $content = file_get_contents($url,fal,$context); //匹配img标签,将所有匹配字符串保存到数组$matches $reg = "/<img.*?src=\"(.*?)\".*?>/i"; preg_match_all($reg, $content, $matches); $count 比较好的微信号id号= count($matches[0]); for ($i=0; $i<$count; $i++){ /*将所有图片的url转换为小写 *$matches[1][$i] = strtolower($matches[1][$i]); */ //如果图片为相对路径就转化为全路径 if (!strpos('a'.$matches[1][$expensive的同义词i], 'http')){ //因为'/'是第0个位置 if (strpos('a'.$matches[1][$i], '/')){ $matches[1][$i] = 'http://'.$main_url.$matches[1][$i]; }el{ $matches[1][$i] = $ba_url.$matches[1][$i]; } } } //过滤重复的图片 $img_arr = array_unique($matches[1]); //实例化图片下载类 $getimg = new downimage(); $url_count = count($img_arr); for ($i=0; $i<$url_count; $i++){ $getimg->source = $img_arr[$i]; $getimg->save_address = './pic/'; $file = $getimg->download(); } echo "下载完成!哈哈,简单吧!";}class downimage{ public $source;//远程图片url public $save_address;//保存本地地址 public $t_extension; //设置图片扩展名 public $quality; //图片的质量(0~100,100最佳,默认75左右) //下载方法(选用gd库图片下载) public function download(){ //获取远程图片信息 $info = @getimagesize($this->source); //获取图片扩展名 $mime = $info['mime']; $type = substr(strrchr($mime, '/'), 1); //不同的图片类型选择不同的图片生成和保存函数 switch($type){ ca 'jpeg': $img_create_func = 'imagecreatefromjpeg'; $img_save_func = 'imagejpeg'; $new_img_ext = 'jpg'; $image_quality = ist($this->quality) ? $this->quality : 100; break; ca 'png': $img_create_func = 'imagecreatefrompng'; $img_save_func = 'imagepng'; $new_img_ext = 'png'; break; ca 'bmp': $img_create_func = 'imagecreatefrombmp'; $img_save_func = 'imagebmp'; $new_img_ext = 'bmp'; break; ca 'gif': $img_create_func = 'imagecreatefromgif'; $img_save_func = 'imagegif'; $new_img_ext = 'gif'; break; ca 'vnd.wap.wbmp': $img_create_func = 'imagecreatefromwbmp'; $img_save_func = 'imagewbmp'; $new_img_ext = 'bmp'; break; ca 'xbm': $img_create_func = 'imagecreatefromxbm'; $img_save_func = 'imagexbm'; $new_img_ext = 'xbm'; break; default: $img_create_func = 'imagecreatefromjpeg'; $img_save_func = 'imagejpeg'; 绿茶的好处 $new_img_ext = 'jpg'; } //根据是否设置扩展名来合成本地文件名 if (ist($this->t_extension)){ $ext = strrchr($this->source,"."); $strlen = strlen($ext); $newname = baname(substr($this->source,0,-$strlen)).'.'.$new_img_ext; }el{ $newname = baname($this->source); } //生成本地文件路径 $save_address = $this->save_address.$newname; $img = @$img_create_func($this->source); if (ist($image_quality)){ $save_img = @$img_save_func($img,$save_address,$image_quality); }el{ $save_img = @$img_save_func($img,$save_address); } return $save_img; }}?><form method="post" action="">远程url地址:&l医药市场营销t;input type="text" name="url" size=30 /><input type="submit" name="submit" value="下载该页面所有图片" /></form>
运行结果如图:
本文发布于:2023-04-06 18:38:26,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/a0bcfa406d177e39fecaca8917f93e22.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:php中使用gd库实现下载网页中所有图片.doc
本文 PDF 下载地址:php中使用gd库实现下载网页中所有图片.pdf
留言与评论(共有 0 条评论) |