作為一個資深並且專業的扒皮人員,在我從初三開始投入偉大的互聯網中到現在積累了豐富的扒皮經驗。我相信每個做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,則忽略。