请求头:referer,响应头:状态行、refresh、Content-Disposition、页面缓存
原理
- 服务端向客户端游览器发送文件时,如果是浏览器支持的文件类型,一般会默认使用浏览器打开,比如txt、jpg等,会直接在浏览器中显示。1、将response的header设置为浏览器不支持的文件类型
'Content-Disposition': 'attachment; filename='
,浏览器则不会渲染该内容,而是下载文件。Content-Disposition filename可以指定路径和文件名
2、content-type设置为application/octet-stream的话,那就意味着你不想直接显示内容,而是弹出一个文件下载的对话框,文件名为当前接口名
实现【注意自己引入相应模块】
- 方法一:
let _path = path.resolve(__dirname, 'e-router'+'.js')
let stats=fs.statSync(_path)
if(stats.isFile()){
res.set({
'Content-Type': 'application/octet-stream',
'Content-Disposition': 'attachment; filename=' + 'e-router'+'.js',
'Content-Length': stats.size
});
fs.createReadStream(_path).pipe(res);
}else{
console.log('导出的不是文件!')
}
- 方法二
res.download(_path,function(err){
if(err){
console.log(err);
}
});
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。