抓取并下載CSS中所有圖片文件的php代碼
> 話(huà)說(shuō)剛才聽(tīng) NsYta 說(shuō)小邪的主題太白了,杯具。最近太忙,沒(méi)有空,不然就自己搞一個(gè)新主題。
一. 抓取 CSS 中的圖片:
> 1. 首先做好準(zhǔn)備工作:
> 第一步,先把 CSS 原本的路徑存到 $url 變量里,然后把 CSS 的內(nèi)容保存在 abc.css 中。
> 因?yàn)榭紤]到經(jīng)常碰到多個(gè) CSS 文件的狀況,所以小邪沒(méi)有直接填一個(gè) CSS 路徑。
> 而是把幾個(gè) CSS 文件的內(nèi)容合并到一起,全部塞到 abc.css 文件里面即可,嘎嘎嘎。
$data = file_get_contents('abc.css');
> 接著讀取 CSS 文件的內(nèi)容到 $data 變量中,然后用正則式把域名給取出來(lái)。
> 因?yàn)檫@里考慮到很多圖片文件用到了相對(duì)根路徑,比方說(shuō) /img/1.gif 和 img/1.gif。
> 然后 CSS 原地址在 http://www.dhdzp.com/css/ 那么上面的兩個(gè)文件位置是不同的。
> 第一個(gè)文件在 /upload/201109/20110926143903807.gif,因?yàn)樗穆窂接玫搅讼鄬?duì)根路徑。
> 而第二個(gè)在 /upload/201109/20110926143903169.gif,它的路徑只是普通的相對(duì)路徑。
$url = 'http://www.dhdzp.com/css/'; preg_match('/(.*\/\/.*?)\//',$url,$host);
//這里用正則式把 http://www.dhdzp.com/ 給取出來(lái),后端不要忘記加斜杠喔。
//.*? 是懶惰匹配,也就是能匹配得越少就匹配越少的內(nèi)容,這樣就不會(huì)取過(guò)頭了。
$host = $host[1];

2. 把圖片存儲(chǔ)文件夾建好:
> 小邪這里用了 is_dir 來(lái)確定文件夾是否存在,存在的話(huà),就不用再建立第二遍了。
> 呵呵,順便說(shuō)下,is_file 函數(shù)可以確定此文件是否為正常文件,也可以確定是否存在。
> 但 file_exists() 優(yōu)越一點(diǎn),因?yàn)槟炒慰吹接腥嗽?Webmasterworld.com 上面討論過(guò)。
if (!is_dir('img')) { mkdir('img'); }
> 3. 用正則式把圖片相對(duì)地址取出來(lái):
$regex = '/url\(\'{0,1}\"{0,1}(.*?)\'{0,1}\"{0,1}\)/';
//這里用正則式匹配出圖片地址,要考慮三種情況,即 url(1.gif) url('1.gif') url("1.gif")。
//這三種寫(xiě)法都是可以使用的,所以咱們就用上面的正則把里面的 1.gif 取出來(lái)。
//\'{0,1} 表示單引號(hào)可能出現(xiàn)1次或0次,\" 則表示雙引號(hào)可能出現(xiàn)1次或0次。
//中間必須使用懶惰匹配,不然取出來(lái)的就是 1.gif" 而不是 1.gif 鳥(niǎo),O(∩_∩)P。
preg_match_all($regex,$data,$result);
> 4. 處理這些圖片:
> 首先使用一個(gè)循環(huán),把上面是用正則提取出來(lái)的第一分支內(nèi)容數(shù)組給處理一下。
> 額,這里的第一分支表示正則式里面的第一個(gè)括號(hào)來(lái)著,呵呵,以此類(lèi)推。
foreach ($result[1] as $val) { }
> 然后是用正則式判定,因?yàn)檫€要考慮到這樣 /upload/201109/20110926143903807.gif。
> 這樣是使用了完整的路徑了,而不是想其他的一樣是 /img/1.gif 或者 img/1.gif。
> 所以單獨(dú)判斷一下,然后接著判斷這兩個(gè),看看是 /img/1.gif 還是 img/1.gif。
if (preg_match('/^http.*/',$val)) { $target = $val; }
else if (preg_match('/^\/.*/',$val)) { $target=$host.$val; }
else { $target=$url.$val; }
echo $target."<br/>\r\n";
> 最后把文件名取出來(lái),即 /img/1.gif 中的 1.gif,用于保存文件。
preg_match('/.*\/(.*\.\D+)$/',$val,$name);
> 然后咱們就可以開(kāi)始下載了,這里要介紹一個(gè)強(qiáng)大的 Copy 函數(shù)用法。
if (!is_file('./img/'.$name[1])) {
$imgc = file_get_contents($target);
$handle = fopen('./img/'.$name[1],'w+');
fwrite($handle,$imgc);
fclose($handle);
}
> 上面那個(gè)是咱們的老方法了,嘎嘎,很麻煩。某次,小邪突然發(fā)現(xiàn) Copy 的強(qiáng)大。
> Copy 居然也可以下載,所以可以輕松使用下面的代碼來(lái)處理,上面的可以退休鳥(niǎo)。
if (!is_file('./img/'.$name[1])) {
copy($target,'./img/'.$name[1]);
}
> 5. 完整源代碼:
> 使用的時(shí)候把 $url 填好即可,然后把所有 CSS 內(nèi)容存到 abc.css 中即可。
<?php
$url = 'http://www.dhdzp.com/css/';
$data = file_get_contents('abc.css');
preg_match('/(.*\/\/.*?)\//',$url,$host);
$host = $host[1];
if (!is_dir('img')) { mkdir('img'); }
$regex = '/url\(\'{0,1}\"{0,1}(.*?)\'{0,1}\"{0,1}\)/';
preg_match_all($regex,$data,$result);
foreach ($result[1] as $val) {
if (preg_match('/^http.*/',$val)) { $target = $val; }
else if (preg_match('/^\/.*/',$val)) { $target=$host.$val; }
else { $target=$url.$val; }
echo $target."<br/>\r\n";
preg_match('/.*\/(.*\.\D+)$/',$val,$name);
if (!is_file('./img/'.$name[1])) {
copy($target,'./img/'.$name[1]);
}
}?>
- 一個(gè)PHP的遠(yuǎn)程圖片抓取函數(shù)分享
- 分享PHP源碼批量抓取遠(yuǎn)程網(wǎng)頁(yè)圖片并保存到本地的實(shí)現(xiàn)方法
- 基于php實(shí)現(xiàn)七牛抓取遠(yuǎn)程圖片
- PHP抓取遠(yuǎn)程圖片(含不帶后綴的)教程詳解
- PHP 抓取網(wǎng)頁(yè)圖片并且另存為的實(shí)現(xiàn)代碼
- php抓取并保存網(wǎng)站圖片的實(shí)現(xiàn)代碼
- PHP采集類(lèi)Snoopy抓取圖片實(shí)例
- PHP抓取淘寶商品的用戶(hù)曬單評(píng)論+圖片+搜索商品列表實(shí)例
- PHP通過(guò)CURL實(shí)現(xiàn)定時(shí)任務(wù)的圖片抓取功能示例
- php抓取網(wǎng)站圖片并保存的實(shí)現(xiàn)方法
- PHP封裝的遠(yuǎn)程抓取網(wǎng)站圖片并保存功能類(lèi)
相關(guān)文章
php采用curl訪(fǎng)問(wèn)域名返回405 method not allowed提示的解決方法
這篇文章主要介紹了php采用curl訪(fǎng)問(wèn)域名返回405 method not allowed提示的解決方法,需要的朋友可以參考下2014-06-06
PHP+Mysql日期時(shí)間如何轉(zhuǎn)換(UNIX時(shí)間戳和格式化日期)
UNIX時(shí)間戳和格式化日期是我們常打交道的兩個(gè)時(shí)間表示形式,Unix時(shí)間戳存儲(chǔ)、處理方便,但是不直觀(guān),格式化日期直觀(guān),但是處理起來(lái)不如Unix時(shí)間戳那么自如,所以有的時(shí)候需要互相轉(zhuǎn)換,下面給出互相轉(zhuǎn)換的幾種轉(zhuǎn)換方式2012-07-07
隊(duì)列在編程中的實(shí)際應(yīng)用(php)
隊(duì)列(Queue)是運(yùn)算受到限制的一種線(xiàn)性表。只允許在表的一端進(jìn)行插入,而在另一端進(jìn)行刪除元素的線(xiàn)性表。隊(duì)尾(rear)是允許插入的一端。隊(duì)頭(front)是允許刪除的一端??贞?duì)列是不含元素的空表。2010-09-09
centos7環(huán)境下swoole1.9的安裝與HttpServer的使用方法分析
這篇文章主要介紹了centos7環(huán)境下swoole1.9的安裝與HttpServer的使用方法,結(jié)合實(shí)例形式分析了centos7環(huán)境下swoole1.9的安裝、配置方法以及HttpServer的相關(guān)使用技巧,需要的朋友可以參考下2020-03-03
PHP封裝XML和JSON格式數(shù)據(jù)接口操作示例
這篇文章主要介紹了PHP封裝XML和JSON格式數(shù)據(jù)接口操作,結(jié)合實(shí)例形式分析了php針對(duì)xml與json格式數(shù)據(jù)接口封裝相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
淺析關(guān)于PHP位運(yùn)算的簡(jiǎn)單權(quán)限設(shè)計(jì)
本篇文章是對(duì)PHP位運(yùn)算的簡(jiǎn)單權(quán)限設(shè)計(jì)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06

