現在基於WEB頁的HTML的編輯器在新聞系統,文章系統中用得越來越廣,一個網頁一粘就可以保持原來的樣式,同時圖片也可以在這個頁中保持。但是在使用過程中,如果所粘貼頁中的圖片被刪除,就會在自己的頁面上留下一個大大的“X”,影響美觀。以前只好把這個圖片儲存下來,再重新上傳到伺服器上,這樣實在麻煩。能不能讓伺服器自動去下載圖片儲存在伺服器並且替換頁面上的連結?答案是肯定的。
要實現這個功能需要經過三個步驟:
一,取得原頁中的圖片的地址。方法很多,可以用分割字串,也可以用正則匹配。實踐證明用正則匹配最為簡單。經過分析圖片的地址都儲存在<IMG>標籤中。我們可以先取得所有這個標籤。過程如下:
Set objRegExp = New Regexp'設定設定物件
objRegExp.IgnoreCase = True’忽略大小寫
objRegExp.Global = True’設定為全文檢索搜尋
objRegExp.Pattern = "<IMG.+?>"'為了確保能準確地取出圖片地址所以分為兩層配置:首先找到裡面的<IMG>標籤,然後再取出裡面的圖片地址後面的getimgs函數就是實現後一個功能的。
strs=trim(str)
Set Matches =objRegExp.Execute(strs)’開始執行配置
For Each Match in Matches
?RetStr = RetStr &getimgs( Match.Value )’執行第二輪的匹配
Next
所有的圖片在裡面都是這樣的src="http://圖片的地址",所以可以這樣來取得確切的圖片地址:
function getimgs(str)
getimgs=""
Set objRegExp1 = New Regexp
objRegExp1.IgnoreCase = True
objRegExp1.Global = True
objRegExp1.Pattern = "http://.+?"""’取出裡面的地址
set mm=objRegExp1.Execute(str)
For Each Match1 in mm
getimgs=getimgs&"||"&left(Match1.Value,len(Match1.Value)-1)’把裡面的地址串起來備用
next
end function
取得了所有的圖片的地址,我們就可以進行第二步的操作了。
二,下載圖片並儲存在伺服器上。這個又可以分為兩個步驟:一個是取得圖片的內容,另一個是儲存在伺服器上。取得圖片的內容是通過下面的函數來實現的:
function getHTTPPage(url)
on error resume next
dim http
set http=server.createobject("MSXML2.XMLHTTP")‘使用xmlhttp的方法來獲得圖片的內容
Http.open "GET",url,false
Http.send()
if Http.readystate<>4 then
exit function
end if
getHTTPPage=Http.responseBody
set http=nothing
if err.number<>0 then err.Clear
end function
取得了圖片的內容要儲存,給人一種感覺是用FSO來作就可以了,但實際上不行,這樣儲存程式就會出錯,因為FSO不支援流式的檔案,所以我們要調用另一個對象:ADO.STREM。具體的過程如下: