变态重口极致另类在线-波多久久夜色精品国产-波多野结衣在线观看一区-波多野结衣在线观看一区二区-污污的网站免费阅读-污污视频网址

當(dāng)前位置:首頁文章首頁 IT學(xué)院 IT技術(shù)

三步教你如何實(shí)現(xiàn)用XMLHTTP組件解析圖片地址并保存

作者:  來源:  發(fā)布時(shí)間:2011-7-8 11:23:10  點(diǎn)擊:

本文提供給大家分享學(xué)習(xí)的是關(guān)于三步教你如何實(shí)現(xiàn)用XMLHTTP組件解析圖片地址并保存,希望能夠幫助到大家。

現(xiàn)在基于Web頁的HTML的編輯器在新聞系統(tǒng),文章系統(tǒng)中用得越來越廣,一個(gè)網(wǎng)頁一粘就可以保持原來的樣式,同時(shí)圖片也可以在這個(gè)頁中保持。但是在使用過程中,如果所粘貼頁中的圖片被刪除,就會(huì)在自己的頁面上留下一個(gè)大大的“X”,影響美觀。以前只好把這個(gè)圖片保存下來,再重新上傳到服務(wù)器上,這樣實(shí)在麻煩。能不能讓服務(wù)器自動(dòng)去下載圖片保存在服務(wù)器并且替換頁面上的鏈接?答案是肯定的。
要實(shí)現(xiàn)這個(gè)功能需要經(jīng)過三個(gè)步驟:
     一,取得原頁中的圖片的地址。方法很多,可以用分割字符串,也可以用正則匹配。實(shí)踐證明用正則匹配最為簡單。經(jīng)過分析圖片的地址都保存在<img>標(biāo)簽中。我們可以先取得所有這個(gè)標(biāo)簽。過程如下:

Set objRegExp = New Regexp'設(shè)置配置對(duì)象
objRegExp.IgnoreCase = True'忽略大小寫
objRegExp.Global = True'設(shè)置為全文搜索
objRegExp.Pattern = "<img.+?>"'為了確保能準(zhǔn)確地取出圖片地址所以分為兩層配置:首先找到里面的<img>標(biāo)簽,然后再取出里面的圖片地址后面的getimgs函數(shù)就是實(shí)現(xiàn)后一個(gè)功能的。
strs=trim(str)
Set Matches =objRegExp.Execute(strs)'開始執(zhí)行配置
For Each Match in Matches
RetStr = RetStr &getimgs( Match.Value )'執(zhí)行第二輪的匹配
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
     取得了所有的圖片的地址,我們就可以進(jìn)行第二步的操作了。
     二,下載圖片并保存在服務(wù)器上。這個(gè)又可以分為兩個(gè)步驟:一個(gè)是取得圖片的內(nèi)容,另一個(gè)是保存在服務(wù)器上。取得圖片的內(nèi)容是通過下面的函數(shù)來實(shí)現(xiàn)的:
function getHTTPPage(url)
on error resume next
dim http
set http=server.createobject("MSXML2.XMLHTTP")‘使用xmlhttp的方法來獲得圖片的內(nèi)容
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
     取得了圖片的內(nèi)容要保存,給人一種感覺是用FSO來作就可以了,但實(shí)際上不行,這樣保存程序就會(huì)出錯(cuò),因?yàn)镕SO不支持流式的文件,所以我們要調(diào)用另一個(gè)對(duì)象:ADO.STREM。具體的過程如下:
function saveimage(from,tofile)
dim geturl,objStream,imgs
geturl=trim(from)
imgs=gethttppage(geturl)'取得圖片的具休內(nèi)容的過程
Set objStream = Server.CreateObject("ADODB.Stream")'建立ADODB.Stream對(duì)象,必須要ADO 2.5以上版本
objStream.Type =1'以二進(jìn)制模式打開
objStream.Open
objstream.write imgs'將字符串內(nèi)容寫入緩沖
objstream.SaveToFile server.mappath(tofile),2'-將緩沖的內(nèi)容寫入文件
objstream.Close()'關(guān)閉對(duì)象
set objstream=nothing
end function
     所以只要用一個(gè)循環(huán)來把剛才取得的地址中的圖片全部保存下來,具體過程如下:
arrimg=split(retstr,"||")'分割字串,取得里面地址列表
allimg=""
newimg=""
for i=1 to ubound(arrimg)
if arrimg(i)<>"" and instr(allimg,arrimg(i))<1 then'看這個(gè)圖片是否已經(jīng)下載過
fname=baseurl&cstr(i&mid(arrimg(i),instrrev(arrimg(i),".")))
saveimage(arrimg(i),fname)‘保存地址的函數(shù),過程見上面
allimg=allimg&"||"&arrimg(i)'把保存下來的圖片的地址串回起來,以確定要替換的地址
newimg=newimg&"||"&fname'把本地的地址串回起來
end if
next
     第三步就是替換原來的地址了。具體的過程就是下面了:
arrnew=split(newimg,"||")'取得原來的圖片地址列表
arrall=split(allimg,"||")'取得已經(jīng)保存下來的圖片的地址列表
for i=1 to ubound(arrnew)'執(zhí)行循環(huán)替換原來的地址
strs=replace(strs,arrall(i),arrnew(i))
next
cctv=strs
     講到這里,這個(gè)函數(shù)的基本過程就是這樣了,當(dāng)然可以對(duì)它進(jìn)行改造就可以實(shí)現(xiàn)更多的功能,如:加上圖片大小的限制,加上對(duì)本地機(jī)上的圖片下載的限制,以免造成重復(fù)下載圖片。同時(shí)也應(yīng)該看到這個(gè)函數(shù)的不足之處是只能處理靜態(tài)的圖片文件,不能適用程序生成的圖片。

相關(guān)軟件

相關(guān)文章

文章評(píng)論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
主站蜘蛛池模板: 天天射天天射天天干 | 欧美精品亚洲精品日韩 | 日韩在线视频免费不卡一区 | 日本一区二区三区在线观看视频 | 欧美高清在线精品一区二区不卡 | 极品国产高颜值露脸在线 | 麻豆md国产在线观看 | 中国国产一国产一级毛片视频 | 日韩在线视频观看 | 一级日韩片 | 黄色的网站在线观看 | 一级免费黄色 | 一级做a免费视频 | 一级片手机在线 | 国产成人精品.一二区 | 亚洲欧美日韩一区超高清 | 中文字幕第315页 | 成人黄网18免费观看的网站 | 久久亚洲最大成人网4438 | 欧美人善交vides0 | 我要看黄色片 | 成人毛片免费观看视频大全 | 日韩美女va在线毛片免费知 | 曰鲁夜鲁鲁狠狠综合 | 免费看一级特黄a大片 | 无遮挡h纯内动漫在线观看 无遮挡1000部拍拍拍免费观看 | 免费一级录像 | 成人国产一区二区三区精品 | 日本xx网站| 黄色短视频在线免费观看 | 国产二区三区毛片 | 另类异族videosex太狠了 | 99在线精品视频免费观里 | 性香港xxxxx免费视频播放 | 免费视频不卡一区二区三区 | t66y永久入口| 曰曰碰天天碰国产 | 日韩毛片在线视频 | 中文字幕一区在线 | 波多野结衣一二区 | 成年人深夜福利 |