vue axios 实现 文件流下载(前后端分离跨域问题的解决)

本文详细介绍了在Vue项目中使用axios如何实现文件流下载,包括单个文件和批量文件(考虑了目录层级)的下载。同时,针对前后端分离下可能出现的跨域问题,提出了有效的解决方案,特别指出批量下载时,若文件名相同且无目录层级,可能会导致的异常情况。
摘要由CSDN通过智能技术生成

前端代码

 后端以流的形式返回

单个文件下载

    @RequestMapping(value = "download", method = RequestMethod.POST)
    @ApiOperation(value = "单个文件下载")
    public HttpServletResponse download(@RequestBody FileDto fileDto, HttpServletResponse response) {
        InputStream fis = null;
        OutputStream toClient = null;
        try {
            // path是指欲下载的文件的路径。
            String dirPath = cloud_root + fileDto.getPath();
            // 取得文件名。
            String filename = fileDto.getFileName();
            File file = new File(dirPath + "/" + filename);
            fis = new BufferedInputStream(new FileInputStream(file));
            byte[] buffer = new byte[fis.available()];
            fis.read(buffer);
            fis.close();

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值