作為一個資深并且專業的扒皮人員,在我從初三開始投入偉大的互聯網中到現在積累了豐富的扒皮經驗。我相信每個做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 可選。規定要寫入文件的數據??梢允亲址到M或數據流。
mode
可選。規定如何打開/寫入文件。可能的值:
FILE_USE_INCLUDE_PATH
FILE_APPEND
LOCK_EX
context
可選。規定文件句柄的環境。
context 是一套可以修改流的行為的選項。若使用 null,則忽略。