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();
        });
    }

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

相关推荐
明月_清风35 分钟前
打字机效果优化:用 requestAnimationFrame 缓冲高频文字更新
前端·javascript
明月_清风36 分钟前
Markdown 预解析:别等全文完了再渲染,如何流式增量渲染代码块和公式?
前端·javascript
掘金安东尼1 小时前
用 CSS 打造完美的饼图
前端·css
掘金安东尼9 小时前
纯 CSS 实现弹性文字效果
前端·css
牛奶9 小时前
Vue 基础理论 & API 使用
前端·vue.js·面试
牛奶9 小时前
Vue 底层原理 & 新特性
前端·vue.js·面试
anOnion10 小时前
构建无障碍组件之Radio group pattern
前端·html·交互设计
pe7er10 小时前
状态提升:前端开发中的状态管理的设计思想
前端·vue.js·react.js
SoaringHeart11 小时前
Flutter调试组件:打印任意组件尺寸位置信息 NRenderBox
前端·flutter
晚风予星11 小时前
Ant Design Token Lens 迎来了全面升级!支持在 .tsx 或 .ts 文件中直接使用 Design Token
前端·react.js·visual studio code