1

请求头: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);
        }
});

qzuser
31 声望4 粉丝