灯火互联
管理员
管理员
  • 注册日期2011-07-27
  • 发帖数41778
  • QQ
  • 火币41290枚
  • 粉丝1086
  • 关注100
  • 终身成就奖
  • 最爱沙发
  • 忠实会员
  • 灌水天才奖
  • 贴图大师奖
  • 原创先锋奖
  • 特殊贡献奖
  • 宣传大使奖
  • 优秀斑竹奖
  • 社区明星
阅读:3467回复:0

ASP实现文件直接下载

楼主#
更多 发布于:2011-12-15 22:50
在IE进行文档链接时,如果遇到OLE支持的文档,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
%>      


喜欢0 评分0
游客

返回顶部