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

    技术2022-05-19  25

    在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 inputif Request("Filename")="" thenresponse.write "<h1>Error:</h1>Filename is empty!<p>"elsecall 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 filestrFilename = server.MapPath(strFile)' clear the bufferResponse.Buffer = TrueResponse.Clear' create streamSet s = Server.CreateObject("ADODB.Stream")s.Open' Set as binarys.Type = 1' load in the fileon error resume next' check the file existsSet fso = Server.CreateObject("Scripting.FileSystemObject")if not fso.FileExists(strFilename) thenResponse.Write("<h1>Error:</h1>"&strFilename&" does not exists!<p>")Response.Endend if' get length of fileSet f = fso.GetFile(strFilename)intFilelength = f.sizes.LoadFromFile(strFilename)if err thenResponse.Write("<h1>Error: </h1>Unknown Error!<p>")Response.Endend if' send the headers to the users BrowseResponse.AddHeader "Content-Disposition","attachment; filename="&f.nameResponse.AddHeader "Content-Length",intFilelengthResponse.CharSet = "UTF-8"Response.ContentType = "application/octet-stream"' output the file to the browserResponse.BinaryWrite s.ReadResponse.Flush' tidy ups.CloseSet s = NothingEnd Functionend if%>


    最新回复(0)