-
<%@ 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
-
%>