抓取并下載CSS中所有圖片文件的php代碼
> 話說(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.dbjr.com.cn/css/ 那么上面的兩個(gè)文件位置是不同的。
> 第一個(gè)文件在 /upload/201109/20110926143903807.gif,因?yàn)樗穆窂接玫搅讼鄬?duì)根路徑。
> 而第二個(gè)在 /upload/201109/20110926143903169.gif,它的路徑只是普通的相對(duì)路徑。
$url = 'http://www.dbjr.com.cn/css/'; preg_match('/(.*\/\/.*?)\//',$url,$host);
//這里用正則式把 http://www.dbjr.com.cn/ 給取出來(lái),后端不要忘記加斜杠喔。
//.*? 是懶惰匹配,也就是能匹配得越少就匹配越少的內(nèi)容,這樣就不會(huì)取過(guò)頭了。
$host = $host[1];
2. 把圖片存儲(chǔ)文件夾建好:
> 小邪這里用了 is_dir 來(lái)確定文件夾是否存在,存在的話,就不用再建立第二遍了。
> 呵呵,順便說(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.dbjr.com.cn/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抓取淘寶商品的用戶曬單評(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使用fgetcsv讀取csv文件出現(xiàn)亂碼的解決方法
這篇文章主要介紹了php使用fgetcsv讀取csv文件出現(xiàn)亂碼的解決方法,實(shí)例分析了造成亂碼的原因與對(duì)應(yīng)的解決方法,并給出了Linux平臺(tái)下的亂碼解決方法,需要的朋友可以參考下2014-11-11聊聊PHP中require_once()函數(shù)為什么不好用
php中你大概有發(fā)現(xiàn)require_once()不好用,但是沒(méi)有深究過(guò)它為什么不好用,這篇文章從該函數(shù)的定義和用法聊聊不好用的原因,文中講述的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考價(jià)值2021-09-09PHP MYSQL亂碼問(wèn)題,使用SET NAMES utf8校正
PHP操作數(shù)據(jù)庫(kù)的時(shí)候,數(shù)據(jù)庫(kù)中數(shù)據(jù)使用UTF8編碼,在讀出來(lái)的時(shí)候,顯示的全是???????問(wèn)號(hào)亂碼,找了一些資料原來(lái)是在讀取之前進(jìn)行一次編碼設(shè)置2009-11-11php similar_text()函數(shù)的定義和用法
下面小編就為大家?guī)?lái)一篇php similar_text()函數(shù)的定義和用法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05Android App中DrawerLayout抽屜效果的菜單編寫(xiě)實(shí)例
這篇文章主要介紹了Android App中DrawerLayout抽屜效果的菜單編寫(xiě)實(shí)例,包括結(jié)合Toolbar實(shí)現(xiàn)復(fù)合Material Design的策劃菜單例子,需要的朋友可以參考下2016-03-03【CLI】利用Curl下載文件實(shí)時(shí)進(jìn)度條顯示的實(shí)現(xiàn)
這篇文章主要給大家介紹了關(guān)于【CLI】利用Curl下載文件實(shí)時(shí)進(jìn)度條顯示的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03php循環(huán)輸出數(shù)據(jù)庫(kù)內(nèi)容的代碼
今天書(shū)寫(xiě)php的循環(huán)輸出內(nèi)容,總發(fā)現(xiàn)第一篇不能現(xiàn)實(shí),原來(lái)是用php do while語(yǔ)句,后來(lái)改成while所以出現(xiàn)這個(gè)問(wèn)題,都怪學(xué)藝不精啊,特整理下2008-05-05