杏花怎酿酒 2022-08-11 07:38 采纳率: 55%
浏览 392
已结题

springboot vue 下载文件,浏览器未显示下载的文件 只有控制台 Preview 有文件

springboot vue 下载文件,浏览器未显示下载的文件
只有控制台 Preview 有文件

img

img


    @PostMapping("/down")
   public void down(HttpServletResponse response, @Param("id") int id) {
        Backup backup = backupService.getById(id);
          File file=new File(backup.getPath());
        response.setContentType ("application/octet-stream");
         
        String name = file.getName()+".txt";
        try {
            name = new String (name.getBytes (StandardCharsets.UTF_8), "ISO8859-1");
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace ();
        }
        response.addHeader ("Content-Disposition", "attachment;filename=" + name);

        OutputStream opmt = null;

        try {
            opmt = response.getOutputStream ();
            opmt.write (FileUtils.readFileToByteArray (new File (backup.getPath())));
            opmt.close ();
        } catch (IOException e) {
            e.printStackTrace ();
        }
        
}

    async download({id}){ // id=
      const result = await getBackupDown({id}).catch(err=>{
        this.$message.error('网络请求错误')
      })
      if(result.status){
        this.$message.error('下载失败')
      }else {
        this.$message.success('下载成功')
      }

      await this.fetchData()
    },
<a-button value="small" @click="download(item)">下载</a-button>

  • 写回答

8条回答 默认 最新

  • 音药 2022-08-11 08:40
    关注
    
    this.$message.success('下载成功')
        const blob = new Blob([res.data], { type: 'application/vnd.ms-excel;charset=utf-8' })
        let link = document.createElement("a");
        let href = window.URL.createObjectURL(blob); //下载链接
        link.href = href;
        link.text = "下载";
        link.download = "xxx"; //下载后文件名
        document.body.appendChild(link);
        link.click(); //点击下载
        document.body.removeChild(link); //下载完成移除元素
        window.URL.revokeObjectURL(href);  //释放blob对象
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • sannianerban12138 2022-08-12 09:55
    关注

    控制台打印那些字符,就是文件流,你需要在前端定义一个Blob对象来接收这个文件流,并将其转化一个可以下载的url地址,再使用a标签点击地址,就能触发浏览器下载事件了
    代码如下

     
    //在你的then函数里面写如下代码     
    let fileName = "自定义文件名";//下载出来的文件名字,你可以自定义的哦
    let blob = new Blob([response.data], {
       type: "application/vnd.ms-excel"
     }); //1.创建一个blob
    lett aDom= document.createElement("a"); //2.创建一个a链接
    aDom.download = fileName; //3.设置名称
    aDom.style.display = "none"; // 4.默认不显示
    aDom.href = URL.createObjectURL(blob); // 5.设置a链接href
    document.body.appendChild(aDom); //6.将a链接dom插入当前html中
    aDom.click(); //7.点击事件,触发下载文件
    document.body.removeChild(aDom); //9.移除a链接dom
    
    
    评论
  • 关注

    是你自己没处理返回的流吧😓,你需要自己构建一个a标签的dom节点然后把流绑定上去之后自己触发一个click事件模拟用户点击a标签下载,或者你直接用window.open打开下载链接浏览器就会自动处理

    评论
  • 专业些bug中 2022-08-11 08:29
    关注
    评论
  • 我啥都会 2022-08-11 09:14
    关注

    这个是第一次搞这功能都可能遇见的问题,我之前也遇到了,主要原因就是:流虽然下载到前端了,但是并没有对流进行文件保存。对应处理代码如下:

    
    //在前台  调用导出接口的回调中写入一下代码      
    const fileName = "自定义文件名";//例如a.txt等 
     //   res.data:请求到的二进制数据
    const blob = new Blob([response.data], {
       type: "application/vnd.ms-excel"
     }); //1.创建一个blob
    const link = document.createElement("a"); //2.创建一个a链接
    link.download = fileName; //3.设置名称
    link.style.display = "none"; // 4.默认不显示
    link.href = URL.createObjectURL(blob); // 5.设置a链接href
    document.body.appendChild(link); //6.将a链接dom插入当前html中
    link.click(); //7.点击事件
    URL.revokeObjectURL(link.href); //8.释放url对象
    document.body.removeChild(link); //9.移除a链接dom
    
    评论
  • 崽崽的谷雨 2022-08-11 09:22
    关注
    评论
  • wade3po 2022-08-12 09:15
    关注
    评论
  • CSDN-Ada助手 CSDN-AI 官方账号 2022-08-12 17:17
    关注
    你可以参考下这篇文章:Springboot+Vue实现文件下载功能
    评论
查看更多回答(7条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 8月14日
  • 已采纳回答 8月12日
  • 创建了问题 8月11日

悬赏问题

  • ¥15 关于网上一个easyx制作的见缝插针小游戏(c++)
  • ¥15 开地址法双散列函数处理碰撞
  • ¥15 想问一下这个是什么情况 虚拟机Linux打不开了
  • ¥15 联通光猫掉注册了怎么重新注册上去
  • ¥15 关于unity开发steamvr程序遇到的问题
  • ¥60 求tc downloader的下载方式
  • ¥15 华为 快捷方式 手电筒 接口
  • ¥15 Qt6.5支不支持Android13开发啊
  • ¥20 网络只能跑一半,应该如何设置
  • ¥20 Python调用百度开发者平台人脸识别接口