Java Web 实现下载文件

一、JAVA服务端

1、实现代码

response.reset();
String fileName = URLEncoder.encode("成绩.xlsx", "UTF-8");
// 设置文件头:最后一个参数是设置下载文件名
response.setHeader("Content-disposition", "attachment; filename="+fileName);
// 设置文件ContentType类型,这样设置,会自动判断下载文件类型  
response.setContentType("multipart/form-data");  
//response.setContentType("application/vnd.ms-excel;charset=utf-8");
response.setCharacterEncoding("utf-8");
OutputStream os = response.getOutputStream();
WriteExcel.WriteExcel(sheetList, os);
response.flushBuffer();

2、Response.setContentType 可设置属性

内容类型文件扩展名描述
application/msworddocMicrosoft Word
application/octet-stream bindms lha lzh exe class可执行程序
application/pdfpdfAdobe Acrobat
application/postscriptai eps psPostScript
appication/powerpointpptMicrosoft Powerpoint
appication/rtfrtfrtf 格式
appication/x-compresszunix 压缩文件
application/x-gzipgzgzip
application/x-gtargtartar 文档 (gnu 格式 )
application/x-shockwave-flashswfMacroMedia Flash
application/x-tartartar(4.3BSD)
application/zipzipwinzip
audio/basicau sndsun/next 声音文件
audio/mpegmpeg mp2Mpeg 声音文件
audio/x-aiffmid midi rmfMidi 格式
audio/x-pn-realaudioram raReal Audio 声音
audio/x-pn-realaudio-pluginrpmReal Audio 插件
audio/x-wavwavMicrosoft Windows 声音
p_w_picpath/cgmcgm计算机图形元文件
p_w_picpath/gifgifCOMPUSERVE GIF 图像
p_w_picpath/jpegjpeg jpg jpeJPEG 图像
p_w_picpath/pngpngPNG 图像
text/htmlHTMLhtml页面
text/plainTXT文本
text/xmltext/xmlxml
text/jsonjson字符串json字符串

更多类型:
response.setContentType()的作用及参数
https://blog.csdn.net/qq_25775675/article/details/132541959

3、参考

Java文件下载,自定义下载名称
https://blog.csdn.net/chmod_R_755/article/details/77893756

解决getWriter() has already been called for this response异常
https://blog.csdn.net/li396864285/article/details/78122296

Java下载excel
https://www.cnblogs.com/xx0405/p/7230315.html

Java 文件下载,文件名乱码问题解决。

https://blog.csdn.net/qq_25775675/article/details/125537539

二、web客户端

1、html 实现

<a download="data.xlsx" href="download?filename=filename.txt" rel="external nofollow">导出</a>

或者使用js动态创建a标签

<button type="button" onclick="download()">导出</button>
function download() {
    var a = document.createElement('a');
    a.href = 'download?filename=filename.txt';
    a.download = 'data.xlsx';
    a.click()
}

2、JS 打开链接

let paramStr = "?id=123456";
// 使用encodeURI,防止中文乱码
window.open("download" + encodeURI(paramStr));

3、模拟表单

// 模拟表单提交同步方式下载文件
// 能够弹出保存文件对话框
function downloadFileByForm() {
    var url = "http://localhost:8080/ajaxDownloadServlet.do";
    var fileName = "filename.txt";
    var form = $("<form></form>").attr("action", url).attr("method", "post");
    form.append($("<input></input>").attr("type", "hidden").attr("name", "fileName").attr("value", fileName));
    form.appendTo('body').submit().remove();
}

4、AJAX 请求二进制流

使用AJAX请求一个二进制流(文件),转换为Blob进行处理或者下载保存文件。

(1)错误方式

<button type="button" onclick="download()">导出</button>
function download() {
    var url = 'download';
    $.get(url, function (data) {
        console.log(typeof(data))
        blob = new Blob([data])
        var a = document.createElement('a');
        a.download = 'data.xlsx';
        a.href = window.URL.createObjectURL(blob)
        a.click()
    })
}

这种方式保存的文件是不能打开的,console.log(typeof(data))会看到是string类型,原因是jquery将返回的数据转换为了string,不支持blob类型。

(2)正确方式

<button type="button" onclick="download()">导出</button>
function download() {
    var url = 'download/?filename=aaa.txt';
    var xhr = new XMLHttpRequest();
    xhr.open('GET', url, true);    // 也可以使用POST方式,根据接口
    xhr.responseType = "blob";  // 返回类型blob
    // 定义请求完成的处理函数,请求前也可以增加加载框/禁用下载按钮逻辑
    xhr.onload = function () {
        // 请求完成,返回200
        if (this.status === 200) {
            var blob = this.response;
            var reader = new FileReader();
            reader.readAsDataURL(blob);  // 转换为base64,可以直接放入a表情href
            reader.onload = function (e) {
                // 转换完成,创建一个a标签用于下载
                var a = document.createElement('a');
                a.download = 'data.xlsx';
                a.href = e.target.result;
                $("body").append(a);  // 修复firefox中无法触发click
                a.click();
                $(a).remove();
            }
        }
    };
    // 发送ajax请求
    xhr.send()
}

参考:https://www.jb51.net/article/122797.htm

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值