如果你的response参数是node.js的http.ServerResponse的话,你可以
fs.createReadStream('你的文件的路径').pipe(response)代码如下:<html>
<head>
<meta http-equiv="Content-Type" content="text/htmlcharset=gbk" />
<title>JS实现下载文件</title>
<script language=JavaScript>
function download(obj){
if(document.all.ifrm==null){
objIframe=document.createElement("IFRAME")
document.body.insertBefore(objIframe)
objIframe.outerHTML="<iframe name=ifrm style='width:0hieght:0' src="+obj.href+"></iframe>"
re=setTimeout("download()",1)
}
else{
clearTimeout(re)
files=window.open(obj.href,"ifrm")
files.document.execCommand("SaveAs")
document.all.ifrm.removeNode(true)
}}
</script>
</head>
<body >
文档列表:请点出下载<br/>
<a href="file01.doc" id="filelist" onclick="download()return false" style="cursor:hand">文件1</a> <br/>
<a href="file02.pdf" id="filelist" onclick="download()return false" style="cursor:hand">文件2</a>
</body>
</html>
如果被下载的目标文件是*.exe或*.zip , *.rar 等格式,用普通的超链接就可以点击下载了。<a href="test.rar">点击这里下载</a>
如果被下载的文件是文本类型,比如是 *.txt , *.html 就不能这样做了,点击后会直接在浏览器显示,而不会弹出下载窗口。
用js是处理不了的,只能在服务器端使用动态脚本输出这些文件。例如:用asp代码调用adodb.stream对象读取文件内容,再输出流数据到浏览器端就会弹出下载界面。