tempad
ReadyGo!技术成就梦想 >>ASP技巧 >> asp中自定义文件下载

asp中自定义文件下载

ReadyGo!技术成就梦想 网络搜索 efish 2008-2-24 3:06:55

可以用流下载(耗内存,少用)或直接转到该文件.


<%

Const USE_STREAM = 0 "0.不用流(Adodb.Stream)下载 1.用流下载
Const ALLOW_FILE_EXT = "rar,zip,chm,doc,xls,swf,mp3,gif,jpg,jpeg,png,bmp" "允许下载的文件的扩展名,防止源代码被下载

Dim sDownFilePath "下载文件路径
sDownFilePath = Trim(Request("FilePath"))
"或者根据传过来的文件ID从数据库中获取文件路径

"如果 sDownFilePath 为绝对路径,一定要将 sDownFilePath 转换为相对 本文件的相对路径

"sDownFilePath = "focus.swf"

Call DownloadFile(sDownFilePath)

Function DownloadFile(s_DownFilePath)
    "判断有没传递文件名
    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

    "检测服务器是否支持Adodb.Stream
    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.Tyep = 1
    o_Stream.Open
    o_Stream.LoadFromFile s_FileMapPath

    Response.Buffer = True
    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

    o_Stream.Close
    Set o_Stream = Nothing

End Function

Sub OutputErr(s_ErrMsg)
    Response.Write "<font color=red>" & s_ErrMsg & "</font>"
    Response.End
End Sub

%>

http://www.cnblogs.com/jiny-z/archive/2006/08/29/489102.html

责任编辑: efish 参与评论 查找更多:
相关文章
UTF-8转GB2312函数 UTF-8转GB2312函数
几种常用排序算法(asp) 几种常用排序算法(asp)
用AspJpeg组件,按宽高比例,真正生成缩略图 用AspJpeg组件,按宽高比例,真正生成缩略图
asp连接数据库的方法(全) asp连接数据库的方法(全)
将内容自动添加到指定文本域的JS 将内容自动添加到指定文本域的JS
ASP二进制流方法隐藏图片文件真实地址 ASP二进制流方法隐藏图片文件真实地址
PRB:ASP 返回“Operation Must Use an Updateable … PRB:ASP 返回“Operation Must Use an Updateable Query”(操作必须使用可更新的查询)错误
对ASP动态包含文件方法的改进 对ASP动态包含文件方法的改进
整站二进制数据库文件还原 整站二进制数据库文件还原
实用的ASP连接数据库的函数 实用的ASP连接数据库的函数
2秒记住本站域名

玩过泡泡龙吗?Readygo?Go! 再加上.Com.Cn的后缀,那就是大名小顶的ReadyGo.com.cn

分类导航
ReadyGo!技术成就梦想