站内搜索
最近浏览
- MySql替换数据库内容
- [J2EE]J2EE 应用服务器技术
- IIS 7 下限制站点带宽和...
- [数据库]sql serve...
- linkd.exe目录映射工...
- thinkphp提示PHP ...
- [web站点]在IIS上开设...
- [网络服务器]如何保证服务器...
- dedecms网站写权限
- MYSQL启用日志,查看日志...
- thinkphp的设置方法
- [数据库]查看sql ser...
- VC++ 重启服务,停止服务...
- 微软IE 7浏览器曝出第二个...
- 微软承认系统严重漏洞 Win...
推荐文章
热文排行
ASP实现文件直接下载
在IE进行文档链接时,如果遇到OLE支持的文档,IE会自动调用相应程序打开它,有时候这种功能并不是我们所需的,虽然我们可以提醒用户用鼠标右键-->"目标另存为...."命令来下载文档,但这样毕竟不太友好,本文描述了利用FSO及Stream方法实现IE直接下载文档.
<%@ language=vbscript codepage=65001%>
<%
''Filename must be input
if Request("Filename")="" then
response.write "<h1>Error:</h1>Filename is empty!<p>"
else
call downloadFile(replace(replace(Request("Filename"),"\",""),"/",""))
Function downloadFile(strFile)
'' make sure you are on the latest MDAC version for this to work
'' get full path of specified file
strFilename = server.MapPath(strFile)
'' clear the buffer
Response.Buffer = True
Response.Clear
'' create stream
Set s = Server.CreateObject("ADODB.Stream")
s.Open
'' Set as binary
s.Type = 1
'' load in the file
on error resume next
'' check the file exists
Set fso = Server.CreateObject("Scripting.FileSystemObject")
if not fso.FileExists(strFilename) then
Response.Write("<h1>Error:</h1>"&strFilename&" does not exists!<p>")
Response.End
end if
'' get length of file
Set f = fso.GetFile(strFilename)
intFilelength = f.size
s.LoadFromFile(strFilename)
if err then
Response.Write("<h1>Error: </h1>Unknown Error!<p>")
Response.End
end if
'' send the headers to the users Browse
Response.AddHeader "Content-Disposition","attachment; filename="&f.name
Response.AddHeader "Content-Length",intFilelength
Response.CharSet = "UTF-8"
Response.ContentType = "application/octet-stream"
'' output the file to the browser
Response.BinaryWrite s.Read
Response.Flush
'' tidy up
s.Close
Set s = Nothing
End Function
end if
%>
<%@ language=vbscript codepage=65001%>
<%
''Filename must be input
if Request("Filename")="" then
response.write "<h1>Error:</h1>Filename is empty!<p>"
else
call downloadFile(replace(replace(Request("Filename"),"\",""),"/",""))
Function downloadFile(strFile)
'' make sure you are on the latest MDAC version for this to work
'' get full path of specified file
strFilename = server.MapPath(strFile)
'' clear the buffer
Response.Buffer = True
Response.Clear
'' create stream
Set s = Server.CreateObject("ADODB.Stream")
s.Open
'' Set as binary
s.Type = 1
'' load in the file
on error resume next
'' check the file exists
Set fso = Server.CreateObject("Scripting.FileSystemObject")
if not fso.FileExists(strFilename) then
Response.Write("<h1>Error:</h1>"&strFilename&" does not exists!<p>")
Response.End
end if
'' get length of file
Set f = fso.GetFile(strFilename)
intFilelength = f.size
s.LoadFromFile(strFilename)
if err then
Response.Write("<h1>Error: </h1>Unknown Error!<p>")
Response.End
end if
'' send the headers to the users Browse
Response.AddHeader "Content-Disposition","attachment; filename="&f.name
Response.AddHeader "Content-Length",intFilelength
Response.CharSet = "UTF-8"
Response.ContentType = "application/octet-stream"
'' output the file to the browser
Response.BinaryWrite s.Read
Response.Flush
'' tidy up
s.Close
Set s = Nothing
End Function
end if
%>
[wangjy17908]
添加时间:2007-09-22