余志国网站设计工作室是专业从事义乌网站建设、义乌外贸网站建设、义乌网站制作、义乌网站设计的专业义乌网站建设工作室,是义乌外贸网站建设专家!

ASP实现点击链接直接下载文件的代码

分类:程序开发 Tags: asp 链接 评论:0 浏览:7901 最近更新时间:2014/8/23 13:45:59

在ie中点开图片或文档的链接里,IE会自动打开它,有时候这种功能并不是我们所需的,虽然我们可以提醒用户用鼠标右键-->"目标另存为...."命令来下载文档或图片,但这样毕竟不太方便,本文是利用FSO及Stream方法直接实现IE直接下载文档。

<%@ language=vbscript codepage=65001%>   
<%   
'Filename must be input   
if Request("Filename")="" then   
response.write "<h1>Error:</h1>Filename is empty!<p>"  
else   
call downloadFile(replace(replace(Request("Filename"),"",""),"/",""))  
Function downloadFile(strFile)  
' make sure you are on the latest MDAC version for this to work  
' get full path of specified file  
strFilename = server.MapPath(strFile)  
' clear the buffer  
Response.Buffer = True  
Response.Clear  
' create stream  
Set s = Server.CreateObject("ADODB.Stream")  
s.Open  
' Set as binary  
s.Type = 1  
' load in the file  
on error resume next  
' check the file exists  
Set fso = Server.CreateObject("Scripting.FileSystemObject")  
if not fso.FileExists(strFilename) then  
Response.Write("<h1>Error:</h1>"&strFilename&" does not exists!<p>")  
Response.End  
end if  
' get length of file  
Set f = fso.GetFile(strFilename)  
intFilelength = f.size  
s.LoadFromFile(strFilename)  
if err then  
Response.Write("<h1>Error: </h1>Unknown Error!<p>")  
Response.End  
end if  
' send the headers to the users Browse  
Response.AddHeader "Content-Disposition","attachment; filename="&f.name  
Response.AddHeader "Content-Length",intFilelength  
Response.CharSet = "UTF-8"  
Response.ContentType = "application/octet-stream"   
' output the file to the browser   
Response.BinaryWrite s.Read   
Response.Flush   
' tidy up   
s.Close   
Set s = Nothing  
End Function  
end if   
%>  
<%@ language=vbscript codepage=65001%>
<%
'Filename must be input
if Request("Filename")="" then
response.write "<h1>Error:</h1>Filename is empty!<p>"
else
call downloadFile(replace(replace(Request("Filename"),"",""),"/",""))
Function downloadFile(strFile)
' make sure you are on the latest MDAC version for this to work
' get full path of specified file
strFilename = server.MapPath(strFile)
' clear the buffer
Response.Buffer = True
Response.Clear
' create stream
Set s = Server.CreateObject("ADODB.Stream")
s.Open
' Set as binary
s.Type = 1
' load in the file
on error resume next
' check the file exists
Set fso = Server.CreateObject("Scripting.FileSystemObject")
if not fso.FileExists(strFilename) then
Response.Write("<h1>Error:</h1>"&strFilename&" does not exists!<p>")
Response.End
end if
' get length of file
Set f = fso.GetFile(strFilename)
intFilelength = f.size
s.LoadFromFile(strFilename)
if err then
Response.Write("<h1>Error: </h1>Unknown Error!<p>")
Response.End
end if
' send the headers to the users Browse
Response.AddHeader "Content-Disposition","attachment; filename="&f.name
Response.AddHeader "Content-Length",intFilelength
Response.CharSet = "UTF-8"
Response.ContentType = "application/octet-stream"
' output the file to the browser
Response.BinaryWrite s.Read
Response.Flush
' tidy up
s.Close
Set s = Nothing
End Function
end if
%>


本文地址:/510/
  • 相关文章
  • 推荐文章
  • 最新文章
发表评论





您的IP:18.97.14.91,来自:

留言

 


免费咨询
建站咨询热线
15967985565
QQ: 358758308 Skype: yuzhiguo Facebook: yuzhiguo Email