asp读取远程文件并保存到本地代码
网络编程 2021-07-05 10:58www.168986.cn编程入门
<%
dim act,ifLogin,loginUrl,loginActUrl,loginData,fileUrl,fileName
act=request.QueryString("act")
if(act="do") then
ifLogin=Cint(request.QueryString("ifLogin"))
loginActUrl=request.Form("loginActUrl")
loginData=request.Form("loginData")
fileUrl=request.Form("fileUrl")
fileName=mid(fileUrl,instrrev(fileUrl,"/")+1)
extPos=instrrev(fileName,"?")
if(extPos>0) then
fileName=left(fileName,extPos-1)
end if
if(ifLogin=1) then
call PostHttpPage(loginActUrl,loginData)
end if
call DownloadFile(fileUrl,fileName)
else
%>
<form name="form1" method="post" action="?act=do">
<p>是否登录
<input name="ifLogin" type="radio" value="1">
是
<input name="ifLogin" type="radio" value="0" checked>
否 </p>
<p>登录提交地址
<input name="loginActUrl" type="text" size="50">
</p>
<p>
登录数据<input name="loginData" type="text" size="50">
</p>
<p>
要保存的远程文件URL
<input name="fileUrl" type="text" size="50">
</p>
<p>
<input type="submit" name="Submit" value="提交">
<input type="reset" name="Submit2" value="重写">
</p>
</form>
<%
end if
Function BytesToBstr(body,code)
dim objstream
set objstream = Server.CreateObject("adodb.stream")
objstream.Type = 1
objstream.Mode =3
objstream.Open
objstream.Write body
objstream.Position = 0
objstream.Type = 2
objstream.Charset =code
BytesToBstr = objstream.ReadText
objstream.Close
set objstream = nothing
End Function
Function PostHttpPage(loginActUrl,PostData)
Dim xmlHttp
Dim RetStr
Set xmlHttp = CreateObject("Microsoft.XMLHTTP")
xmlHttp.Open "POST", loginActUrl, False
XmlHTTP.setRequestHeader "Content-Length",Len(PostData)
xmlHttp.setRequestHeader "Content-Type", "application/x--form-urlencoded"
xmlHttp.Send PostData
If Err.Number <> 0 Then
Set xmlHttp=Nothing
response.Write("提交登录时出错!提交数据"&PostData)
Exit Function
End If
PostHttpPage=BytesToBstr(xmlHttp.responseBody,"GB2312")
Set xmlHttp = nothing
End Function
'''''''''''''''''''''''''''''''''''''''''''
function DownloadFile(url,filename)
Set xml = Server.CreateObject("Msxml2.XMLHTTP") '创建对象
xml.Open "GET",url,False
xml.Send '发送请求
if Err.Number>0 then
Response.Status="404"
else
Response.ContentType="application/octet-stream"
Response.AddHeader "Content-Disposition:","attachment; filename=" & filename
Range=Mid(Request.ServerVariables("HTTP_RANGE"),7)
if Range="" then
Response.BinaryWrite(xml.responseBody)
else
S.position=Clng(Split(Range,"-")(0))
Response.BinaryWrite(xml.responseBody)
End if
end if
Response.End
Set xml = Nothing
end function
'''''''''''''''''''''''''''''''''''''''''''''''''''''
%>
dim act,ifLogin,loginUrl,loginActUrl,loginData,fileUrl,fileName
act=request.QueryString("act")
if(act="do") then
ifLogin=Cint(request.QueryString("ifLogin"))
loginActUrl=request.Form("loginActUrl")
loginData=request.Form("loginData")
fileUrl=request.Form("fileUrl")
fileName=mid(fileUrl,instrrev(fileUrl,"/")+1)
extPos=instrrev(fileName,"?")
if(extPos>0) then
fileName=left(fileName,extPos-1)
end if
if(ifLogin=1) then
call PostHttpPage(loginActUrl,loginData)
end if
call DownloadFile(fileUrl,fileName)
else
%>
<form name="form1" method="post" action="?act=do">
<p>是否登录
<input name="ifLogin" type="radio" value="1">
是
<input name="ifLogin" type="radio" value="0" checked>
否 </p>
<p>登录提交地址
<input name="loginActUrl" type="text" size="50">
</p>
<p>
登录数据<input name="loginData" type="text" size="50">
</p>
<p>
要保存的远程文件URL
<input name="fileUrl" type="text" size="50">
</p>
<p>
<input type="submit" name="Submit" value="提交">
<input type="reset" name="Submit2" value="重写">
</p>
</form>
<%
end if
Function BytesToBstr(body,code)
dim objstream
set objstream = Server.CreateObject("adodb.stream")
objstream.Type = 1
objstream.Mode =3
objstream.Open
objstream.Write body
objstream.Position = 0
objstream.Type = 2
objstream.Charset =code
BytesToBstr = objstream.ReadText
objstream.Close
set objstream = nothing
End Function
Function PostHttpPage(loginActUrl,PostData)
Dim xmlHttp
Dim RetStr
Set xmlHttp = CreateObject("Microsoft.XMLHTTP")
xmlHttp.Open "POST", loginActUrl, False
XmlHTTP.setRequestHeader "Content-Length",Len(PostData)
xmlHttp.setRequestHeader "Content-Type", "application/x--form-urlencoded"
xmlHttp.Send PostData
If Err.Number <> 0 Then
Set xmlHttp=Nothing
response.Write("提交登录时出错!提交数据"&PostData)
Exit Function
End If
PostHttpPage=BytesToBstr(xmlHttp.responseBody,"GB2312")
Set xmlHttp = nothing
End Function
'''''''''''''''''''''''''''''''''''''''''''
function DownloadFile(url,filename)
Set xml = Server.CreateObject("Msxml2.XMLHTTP") '创建对象
xml.Open "GET",url,False
xml.Send '发送请求
if Err.Number>0 then
Response.Status="404"
else
Response.ContentType="application/octet-stream"
Response.AddHeader "Content-Disposition:","attachment; filename=" & filename
Range=Mid(Request.ServerVariables("HTTP_RANGE"),7)
if Range="" then
Response.BinaryWrite(xml.responseBody)
else
S.position=Clng(Split(Range,"-")(0))
Response.BinaryWrite(xml.responseBody)
End if
end if
Response.End
Set xml = Nothing
end function
'''''''''''''''''''''''''''''''''''''''''''''''''''''
%>
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程