Java把文件链接转成流,返回给前端下载

背景:已知Java拿到了一个PDF链接(http://xxx.xxx.pdf),直接把链接返给前端的话,前端是不能点击直接下载的,需要后端先把url转成文件流,再由前端下载,处理如下:
导入pom

xml 复制代码
        <dependency>
            <groupId>org.apache.pdfbox</groupId>
            <artifactId>pdfbox</artifactId>
            <version>2.0.24</version>
        </dependency>

接口部分

java 复制代码
    @GetMapping("/downloadPdf")
    public void downloadPdf(@RequestParam String patentId, HttpServletResponse response) throws IOException {
        String pdfLink = "http://xxx.xxx.pdf";
        URL url = new URL(pdfLink);
        try (InputStream inputStream = url.openStream();
             PDDocument document = PDDocument.load(inputStream)) {
            // 设置响应头
            response.setContentType("application/pdf");
            response.setHeader("Content-Disposition", "attachment;");

            // 写入响应流
            try (OutputStream outputStream = response.getOutputStream()) {
                document.save(outputStream);
            }
        }
    }

前端部分

javascript 复制代码
    downloadPDF() {
      let url = baseURL + "/xxx/xxx/downloadPdf?patentId=" + this.patent_id; // 对应后端接口
      console.log(url);
      axios({
        method: 'get',
        url: url,
        responseType: 'blob',	// 不加的话会白页
        headers: {'Authorization': 'Bearer ' + getToken()}
      })
        .then(response => {
          const blob = new Blob([response.data]);
          const url = URL.createObjectURL(blob);
          const link = document.createElement('a');
          link.href = url;
          link.download = `xxx.pdf`;	// 下载的文件名字
          link.click();
        });
    }

这样前端一点击,就能直接下载。

相关推荐
蓝婷儿27 分钟前
第二章:CSS秘典 · 色彩与布局的力量
前端·css
flying robot29 分钟前
js在浏览器执行原理
开发语言·javascript·ecmascript
Wyc724091 小时前
HTML:入门
前端·html
Sunny_lxm1 小时前
自定义列甘特图,原生开发dhtmlxgantt根特图,根据数据生成只读根特图,页面展示html demo
前端·html·甘特图·dhtmlxgantt
熊猫钓鱼>_>2 小时前
建筑IT数字化突围:建筑设计企业的生存法则重塑
前端·javascript·easyui
代码小将2 小时前
Leetcode209做题笔记
java·笔记·算法
专注_每天进步一点点2 小时前
idea 启动Springboot项目在编译阶段报错:java: OutOfMemoryError: insufficient memory
java·spring boot·intellij-idea
dhxhsgrx3 小时前
PYTHON训练营DAY25
java·开发语言·python
GISer_Jing4 小时前
前端性能指标及优化策略——从加载、渲染和交互阶段分别解读详解并以Webpack+Vue项目为例进行解读
前端·javascript·vue
不知几秋4 小时前
数字取证-内存取证(volatility)
java·linux·前端