asp流下載(Stream)

來源:互聯網
上載者:User

<%@ 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("/")&"\Admin_Access\upfiles\"&strFile  
  strFilename  =  server.MapPath("Upfiles/"&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   
'Response.Write strFilename
'  check  the  file  existsSet  fso  =  Server.CreateObject("Scripting.FileSystemObject")   
if  not  fso.FileExists(strFilename)  then   
'Response.Write("<h1>Error:</h1>"&strFilename&" does not exists!<p>")
Response.Write("<h1>Error:</h1>"&strFile&" 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-Disposition","attachment;  filename="& Request("Filename")
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
%>  

download.asp?Filename=dasadfsdafs.asp這樣調用就好了啊

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.