加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 站长学院 > Asp教程 > 正文

ASP实现网页开启任何类型文件都提示保存的方法附代码

发布时间:2023-07-25 13:04:06 所属栏目:Asp教程 来源:
导读:相信大家平时都有这样的经历:页面上有一个链接指向服务器一个Word文件,当客户端机器有安装Office时,点击链接将调用Word打开浏览;当客户端机器没有安装Office时,点击链接将弹出保存对话框。总结一下即如果浏览器

相信大家平时都有这样的经历:页面上有一个链接指向服务器一个Word文件,当客户端机器有安装Office时,点击链接将调用Word打开浏览;当客户端机器没有安装Office时,点击链接将弹出保存对话框。总结一下即如果浏览器认识文件类型,就会自动打开;如果不认识,则会提示客户保存。可是有时候我们希望不管什么类型文件,都不要打开,直接让客户端保存。要达到这个要求,对于保存在服务器硬盘上的文件就得利用ASPUpload组件的SendBinary方法来实现,而对于保存在数据库中的文件则只须打开记录集,然后将二进制数据直接输出到客户端即可,不过要告诉浏览器文件的MIME类型、文件名称和文件大小。

1.服务器端硬盘上的文件

代码如下:

<% 

Dim Upload,FilePath 

Set Upload = Server.CreateObject("Persits.Upload") 

FilePath = Server.MapPath(".") & "/" & "2003529213019.txt" 

'SendBinary参数说明: 

'参数一:文件物理路径 

'参数二:是否将文件的MIME类型等信息传送给浏览器 

'参数三:文件类型,可以指定具体的MIME类型,但一般都可以使用application/octet-binary 

'参数四:让客户端保存文件还是直接打开。True:保存;False(默认):打开 

Upload.SendBinary FilePath,True,"application/octet-binary",True 

%> 

2.服务器端数据库中的文件

代码如下:

<% 

Dim objConn,objRs 

Set objConn = Server.CreateObject("ADODB.Connection") 

Set objRs = Server.CreateObject("ADODB.RecordSet") 

objConn.open "Driver={Microsoft Access Driver (*.mdb)};dbq=" & Server.MapPath("db1.mdb") 

objRs.open "select * from t5 where id=2",objConn,1,3 

Response.ContentType = "application/octet-stream" 

Response.AddHeader "Content-Disposition","attachment;filename=" & objRs("filename") 

Response.AddHeader "Content-Length",CStr(objRs("size")) '此处必须用CStr转换 

Response.BinaryWrite objRs("file") 

objRs.close 

Set objRs = nothing 

objConn.close 

Set objConn = nothing 

%> 

此法要求保存文件时需同时保存文件名及文件大小!若未指定文件名及大小,如果浏览器认识该文件类型,将会自动打开;如果不认识,才会提示客户保存!

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章