【问题解决】Axios调用文件下载获取不到文件名

问题描述

自己开发了一个后端下载文件的接口,然后通过浏览器直接访问这个接口,浏览器能正确得到文件名并下载;

而使用Axios时发现获取不到,经过打印响应体发现响应头里没有文件名

而Java后端代码里是有的Content-Disposition 响应头的:

    public static void downloadWithBIO(String fileName, HttpServletResponse response) {
        String simpleName = fileName.substring(fileName.lastIndexOf(File.separator) + 1);
        try {
            response.setContentType("application/octet-stream");
            response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(simpleName, "UTF-8"));
            response.setContentLengthLong(file.length());

            try (OutputStream os = response.getOutputStream();
                    FileInputStream fis = new FileInputStream(new File(fileName));
                    BufferedOutputStream bos = new BufferedOutputStream(os)) {
                byte[] bytes = new byte[4096];
                while (fis.read(bytes) != -1) {
                    bos.write(bytes);
                }
                os.flush();
            }
        } catch (IOException e) {
            throw new BusinessRuntimeException(e);
        }
    }

而且查看网络请求也是包含这个响应头的,所以只能是axios把这些响应头去除了。

问题解决

经查询axios文档发现只要将后端响应时再加一个响应头,axios就能放行指定的响应头

// 放行Content-disposition响应头
response.setHeader("Access-Control-Expose-Headers", "Content-disposition");

后端调整后,前端通过响应头中取响应头就可以了

下载正常

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东北小狐狸-Hellxz

请作者喝杯咖啡

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值