作為一個資深並且專業的扒皮人員,在我從初三開始投入偉大的互連網中到現在積累了豐富的扒皮經驗。我相信每個做web的程式員也都會有類似的經曆。
在扒皮過程中,必不可少的需要下載樣式檔案中的圖片。碰到比較龐大的樣式檔案,其中可能會有上百個需要下載的圖片,那麼使用下面這段小代碼是最為合適的了。
< ?php/* More & Original PHP Framwork Copyright (c) 2007 - 2008 IsMole Inc. Author: kimi Documentation: 下載樣式檔案中的圖片,水水專用扒皮工具*///note 設定PHP逾時時間set_time_limit(0);//note 取得樣式檔案內容$styleFileContent = file_get_contents('images/style.css');//note 匹配出需要下載的URL地址preg_match_all("/url\((.*)\)/", $styleFileContent, $imagesURLArray);//note 迴圈需要下載的地址,逐個下載$imagesURLArray = array_unique($imagesURLArray[1]);foreach($imagesURLArray as $imagesURL) { file_put_contents(basename($imagesURL), file_get_contents($imagesURL));}
再給大家分享一段封裝好的類
/** * 擷取CSS中圖片地址,並且儲存到本地 */class getInCssImage{ /** * 圖片儲存下來* @param $cssUrl css的url地址* @param $dir 儲存圖片的目錄* @return void*/static public function saveImage($cssUrl, $dir){ $content = file_get_contents($cssUrl); $patterns = '/images(.*).(jpg|gif|png)/'; //正則根據不同地址需要變換preg_match_all($patterns, $content, $matches);$imagesUrls = $matches[0];if (!is_dir($dir))mkdir(dirname(__FILE__). '/'. $dir, 0777);foreach($imagesUrls as $image){ ob_start();$imageUrl = "http://www.xx.com/".$image; //這個地址本來用程式給擷取的。偷懶了下readfile($imageUrl);$img = ob_get_contents();ob_end_clean();$size = strlen($img);$localImage = $dir. strchr($image, '/'); //存到本地的圖片地址$fp = fopen($localImage, 'a');fwrite($fp, $img);fclose($fp);} } }}$content = getInCssImage::saveImage('/css/css.css', 'image');
最後預祝各位在扒皮的過程中,一扒到底!
另外附上關於file_put_contents定義和用法
file_put_contents() 函數把一個字串寫入檔案中。
與依次調用 fopen(),fwrite() 以及 fclose() 功能一樣。
文法
file_put_contents(file,data,mode,context)
參數 描述
file 必需。規定要寫入資料的檔案。如果檔案不存在,則建立一個新檔案。
data 可選。規定要寫入檔案的資料。可以是字串、數組或資料流。
mode
可選。規定如何開啟/寫入檔案。可能的值:
FILE_USE_INCLUDE_PATH
FILE_APPEND
LOCK_EX
context
可選。規定檔案控制代碼的環境。
context 是一套可以修改流的行為的選項。若使用 null,則忽略。