使用asp下的adodb.stream 下载文件而不是打开
2018-09-06 10:34
在浏览器的地址栏里直接输入一个doc或xls或jpg的文件的url路径,那么该文件会直接显示在浏览器里。而在很多时候我们希望能直接弹出下载提示框让用户下载,我们该怎么办呢?这里有两种方法:
1、设置你的服务器的iis,给doc等后缀名做映射。
2、在向客户端发送时设置其contenttype。
下面详细说明方法2
程序代码:
<% Response.Buffer = true Response.Clear dim url Dim fso,fl,flsize dim Dname Dim objStream,ContentType,flName,isre,url1 *********************************************调用时传入的下载文件名 Dname=trim(request(n)) ****************************************************************** If Dname<> Then ******************************下载文件存放的服务端目录tentType = ContentType Response.BinaryWrite objStream.Read Response.Flush response.Clear() objStream.Close Set objStream = Nothing %>
将下面的东西存成download.asp然后你就可以用<aherf=?n=file.doc>download!</a>来下载同一目录下的file.doc了!
但是这里有个问题就是直接将file.doc路径写在url里是不安全的,所以解决方案应该是将file.doc的路径存到数据库里,同过查找数据库后得到路径
在这个程序的最前面如果加上一个判断:
if instr(Request.ServerVariables(HTTP_REFERER),的域名)=0 then Response.End end if
就能够很好的防止别人的盗链了.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
上一篇:ASP程序中使用断开的数据记录集
下一篇:asp中实现清除html的函数
文章标题:使用asp下的adodb.stream 下载文件而不是打开
文章链接:http://soscw.com/essay/8680.html