一,获得原页中的图片的地址。

  <%

  function PicStr(str)

  Set objRegExp = New Regexp '设置设置设备摆设对象

  objRegExp.IgnoreCase = True '忽略大小写

  objRegExp.Global = True '设置为全文搜索

  objRegExp.Pattern = "" '为了确保能精确地取出图片地址所以分为两层设置设备摆设:首先找到里面的标签,然后再取出里面的图片地址后面的getimgs函数便是实现后一个功效的。

  strs=trim(str)

  Set Matches =objRegExp.Execute(strs) '开端履行设置设备摆设

  For Each Match in Matches

  PicStr = PicStr &getimgs( Match.Value ) '履行第二轮的匹配

  Next

  '统统的图片在里面都是如许的src="http://图片的地址",所以可以或许或许如许来获得确切的图片地址

  end function

  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。详细的过程如下:

  function saveimage(from,tofile)

  dim geturl,objStream,imgs

  geturl=trim(from)

  imgs=gethttppage(geturl)'获得图片的具休内容的过程

  Set objStream = Server.CreateObject("ADODB.Stream")'树立ADODB.Stream对象,必必要ADO 2.5以上版本

  objStream.Type =1'以二进制情势打开

  objStream.Open

  objstream.write imgs'将字符串内容写入缓冲

  objstream.SaveToFile server.mappath(tofile),2'-将缓冲的内容写入文件

  objstream.Close()'关闭对象

  set objstream=nothing

  end function

  '所以只要用一个回来把刚才获得的地址中的图片全体保留下来,详细过程如下:

  arrimg=split(PicStr(str),"||") '分割字串,获得里面地址列表

  allimg=""

  newimg=""

  for i=1 to ubound(arrimg)

  if arrimg(i)<>"" and instr(allimg,arrimg(i))<1 then '看这个图片是否已经下载过

  fname=baseurl&cstr(i&mid(arrimg(i),instrrev(arrimg(i),".")))

  saveimage(arrimg(i),fname)‘保留地址的函数,过程见上面

  allimg=allimg&"||"&arrimg(i) '把保留下来的图片的地址串回起来,以确定要替换的地址

  newimg=newimg&"||"&fname '把本地的地址串回起来

  end if

  next

  '第三步便是替换本来的地址了。详细的过程便是下面了:

  arrnew=split(newimg,"||") '获得本来的图片地址列表

  arrall=split(allimg,"||") '获得已经保留下来的图片的地址列表

  for i=1 to ubound(arrnew) '履行轮回替换本来的地址

  strs=replace(strs,arrall(i),arrnew(i))

  next

  %>