可以用流下載(耗內存,少用)或直接轉到該文件.
<%
Const USE_STREAM = 0 '0.不用流(Adodb.Stream)下載 1.用流下載 Dim sDownFilePath '下載文件路徑 '如果 sDownFilePath 為絕對路徑,一定要將 sDownFilePath 轉換為相對 本文件的相對路徑 'sDownFilePath = "focus.swf" Call DownloadFile(sDownFilePath) Function DownloadFile(s_DownFilePath) '判斷擴展名是否合法 '為了安全,某些目錄禁止下載文件,在這里處理 '取得文件名,文件大小 '判斷是否下載的文件大小超過限制 '檢測服務器是否支持Adodb.Stream o_Stream.Tyep = 1 Response.Buffer = True o_Stream.Close End Function Sub OutputErr(s_ErrMsg) %> http://www.49028c.com/jiny-z/archive/2006/08/29/489102.html
Const ALLOW_FILE_EXT = "rar,z
sDownFilePath = Trim(Request("FilePath"))
'或者根據傳過來的文件ID從數據庫中獲取文件路徑
'判斷有沒傳遞文件名
If IsNull(s_DownFilePath) = True Or Trim(s_DownFilePath) = "" Then
OutputErr "錯誤:先確定要下載的文件,下載失敗"
End If
Dim s_FileExt
s_FileExt = Mid(s_DownFilePath, InstrRev(s_DownFilePath, ".")+1)
If InStr("," & ALLOW_FILE_EXT & ",", "," & s_FileExt & ",") <= 0 Then
OutputErr "錯誤:文件類型(" & s_FileExt & ")不允許被下載,下載失敗"
End If
s_DownFilePath = Replace(s_DownFilePath, "/", "/")
'
'檢測服務器是否支持fso
Dim o_Fso
On Error Resume Next
Set o_Fso = Server.CreateObject("Scripting.FileSystemObject")
If Err.Number <> 0 Then
Err.Clear
OutputErr "錯誤:服務器不支持fso組件,下載失敗"
End If
Dim s_FileMapPath
Dim o_File, s_FileName, n_FileLength
s_FileMapPath = Server.MapPath(s_DownFilePath)
If (o_Fso.FileExists(s_FileMapPath)) = True Then
Set o_File = o_Fso.GetFile(s_FileMapPath)
s_FileName = o_File.Name
n_FileLength = o_File.Size
o_File.Close
Else
OutputErr "錯誤:文件不存在,下載失敗"
End If
Set o_Fso = Nothing
'
'如果不是用流下載,直接轉到該文件
If USE_STREAM = 0 Then
Response.Redirect sDownFilePath
Response.end
End If
On Error Resume Next
Set o_Stream = Server.CreateObject("Adodb.Stream")
If Err.Number <> 0 Then
Err.Clear
OutputErr "錯誤:服務器不支持Adodb.Stream組件,下載失敗"
End If
o_Stream.Open
o_Stream.LoadFromFile s_FileMapPath
Response.Clear
Response.AddHeader "Content-Disposition", "attachment; filename=" & s_FileName
Response.AddHeader "Content-Length", n_FileLength
Response.CharSet = "UTF-8"
Response.ContentType = "application/octet-stream"
Response.BinaryWrite o_Stream.Read
Response.Flush
Set o_Stream = Nothing
Response.Write "<font color=red>" & s_ErrMsg & "</font>"
Response.End
End Sub
新聞熱點
疑難解答