ASP提取远程图片URL自动上传保存到本地实现代码

网站编辑经常可能会复制被人的文章文章里面的图片如果能自动上传并转换为本地路径就完美了,可以减轻很大的工作量。下面编程之家给下自动提取远程图片上传实现思路与代码

步骤一、取得原网页中的图片的地址。

这个可以用正则匹配,分析提取网页中的<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

取得确切的图片地址:

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

步骤二、将按提取图片地址下载图片,并保存在服务器上。我们仍然需要分为两个步骤:1、取得图片内容,2、保存图片到服务器上。先来看取得图片内容,通过以下函数来实现:

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(retstr,"||")'分割字串,取得里面地址列表

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

cctv=strs

编程之家温馨提醒:你可以对思路代码进行改造,比如添加图片大小的限制

相关文章

数组的定义 Dim MyArray MyArray = Array(1‚5‚123‚12‚98...
\'参数: \'code:要检测的代码 \'leixing:html或者ubb \'n...
演示效果: 代码下载: 点击下载
环境:winxp sp2 ,mysql5.0.18,mysql odbc 3.51 driver 表采...
其实说起AJAX的初级应用是非常简单的,通俗的说就是客户端(j...
<% ’判断文件名是否合法 Function isFilename(aFilename...