我是靠谱客的博主 繁荣手套,最近开发中收集的这篇文章主要介绍后台返回文件流,监听文件下载结束,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1、后台正常返回流即可

@RequestMapping(value = "/download/fileword", method = RequestMethod.GET)
public void downLoad(HttpServletResponse response) {
        try (InputStream in = new FileInputStream(“G://test.docx”);){
            //String gFileName = URLEncoder.encode(fileName, "UTF-8");
            //如进行下载名为:文件(3).txt,下载时显示名为:文件+(3).txt --空格变为了+号
            //解决办法如下
            //String dFileName = gFileName.replaceAll("\+", "%20");
            //设置输出的格式
            response.reset();	//去除前后空格
            //激活浏览器弹出窗口
            //response.setContentType("application/x-msdownload");
            //浏览器弹出窗口显示的文件名
            //response.addHeader("Content-Disposition", "attachment;filename="+dFileName);
            byte[] b = new byte[1024];
            int len;
            while ((len = in.read(b)) > 0){
                response.getOutputStream().write(b, 0, len);
            }
           // File file = new File(WordText.fileNew);
           // file.delete();
        } catch (Exception e){
            e.printStackTrace();
        }

    }

2、前台js代码

var url = "http://192.168.15.127:8080/download/fileword”;
fetch(url, {
	method: 'GEt',
	headers: {'Content-Type': 'application/json'},
	//body: '<请求参数:json字符串>',
}).then(res => res.blob()).then(data => {
	alert("1112");
	var blobUrl = window.URL.createObjectURL(data);
	downloads(blobUrl);
});

function downloads(blobUrl) {
	const a = document.createElement('a');
	a.style.display = 'none';
	a.download = 'aa.docx';
	a.href = blobUrl;
	a.click();
	document.body.removeChild(a);
}

最后

以上就是繁荣手套为你收集整理的后台返回文件流,监听文件下载结束的全部内容,希望文章能够帮你解决后台返回文件流,监听文件下载结束所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部