data:image/s3,"s3://crabby-images/eca9f/eca9f2f56c05c552c853355d850e1be1b77847b1" alt="Rank: 4"
- 帖子
- 120
- 积分
- 470
- 威望
- 636
- 金钱
- 101
- 在线时间
- 31 小时
data:image/s3,"s3://crabby-images/e6314/e631450ec076e04beca50708b36d5c815d6e95e6" alt="原创奖章 原创奖章" data:image/s3,"s3://crabby-images/ccea7/ccea754c16c006eaac7a96f5b73f0d004d0ccb45" alt="帅哥勋章 帅哥勋章" data:image/s3,"s3://crabby-images/b7994/b7994d87c6094df496ed726b46ac9e9625d9a42c" alt="支持奖章 支持奖章" data:image/s3,"s3://crabby-images/b23b3/b23b3fed8495e8121d3d2728c95aaa8a3246c2e7" alt="论坛元老 论坛元老"
|
代码:
<%
strFilename = Trim(Request("n"))
Function DownloadFile(strFile,filename)
strFilename = server.MapPath(strFile)
'清空Buffer
Response.Buffer = True
Response.Clear
'创建Stream对象
Set s = Server.CreateObject("ADODB.Stream")
s.Open
'设置流对象为二进制类型
s.Type = 1
on error resume next
'检测文件是否存在
Set fso = Server.CreateObject("Scripting.FileSystemObject")
If Not fso.FileExists(strFilename) Then
downloadFile="NoFile"
Exit Function
End If
'计算文件长度
Set f = fso.GetFile(strFilename)
intFilelength = f.size
If filename="" Then
filename=f.name
End If
s.LoadFromFile(strFilename)
if err then
Response.Write("<h1>Error: </h1>" & err.Description & "<p>")
Response.End
end if
'向用户浏览器发送Header
Response.AddHeader "Content-Disposition", "attachment; filename=" & filename
Response.AddHeader "Content-Length", intFilelength
Response.CharSet = "UTF-8"
Response.ContentType = "application/octet-stream"
'输出文件
'对于小于4096KB的文件可以用语句
'Response.BinaryWrite s.Read
'Response.Flush
'完成,但对于大于4096KB的文件要分段输出,如下循环操作。
Do While Not s.EOS
Contents = s.Read (4096) '每次读取4096KB
Response.BinaryWrite Contents
Response.Flush
Loop
'清理
s.Close
Set s = Nothing
End Function
call downloadFile(strFilename,strFilename)
%> |
|