avatar

使用axios实现post请求方式下载文件

实现方法

Java请求中设置header请求头参数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
import java.io.File;
import javax.servlet.http.HttpServletResponse;

public class FileUtil {

public static void fileDownload(HttpServletResponse response, File file) {

FileInputStream fileInputStream = null;

ServletOutputStream outputStream = null;

try {

/* 获取文件输入流 */
fileInputStream = new FileInputStream(file);

/* 定义请求头 */
response.setHeader("content-disposition", "attachment;fileName=" + URLEncoder
.encode(file.getName(), CharsetUtil.UTF_8));

/* 设置该请求头后,js能够获取content-disposition请求头数据,从中获取文件名称 */
response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");

/* 从response中获取写入流 */
outputStream = response.getOutputStream();
/* 将文件输入流中的数据写入到response的文件输出流中 */
IOUtils.copy(fileInputStream, outputStream);

} catch (Exception e) {
throw new RuntimeException(e);

/* 资源释放 */
} finally {
try {
if (outputStream != null) outputStream.close();
} catch (Exception e) {
e.printStackTrace();
}
try {
if (fileInputStream != null) fileInputStream.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}

js实现文件流下载处理

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
/* 在axios请求中加入responseType: 'blob'参数,表示接收的数据为二进制文件流 */
axios.post(`请求地址`, 请求需要的数据, {responseType: 'blob'}).then(response => {
/* 从请求头中获取文件名称,用于将文件流转换成对应文件格式的文件,防止文件损坏 */
let split = response.headers['content-disposition'].split("=");
/* 将数据流转换为对应格式的文件,并创建a标签,模拟点击下载,实现文件下载功能 */
let fileReader = new FileReader();
fileReader.readAsDataURL(response.data);
fileReader.onload = e => {
let a = document.createElement('a');
a.download = split[1];
a.href = e.target.result;
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
}
})
文章作者: 123
文章链接: https://gao5805123.github.io/123/2021/04/12/%E4%BD%BF%E7%94%A8axios%E5%AE%9E%E7%8E%B0post%E8%AF%B7%E6%B1%82%E6%96%B9%E5%BC%8F%E4%B8%8B%E8%BD%BD%E6%96%87%E4%BB%B6/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 123
打赏
  • 微信
    微信
  • 支付宝
    支付宝