JAVA下载 PDF 到本地 或 返回文件流

 

@Slf4j
public class PDFUtils {

    /**
     *
     * @param fileUrl 文件路径
     * @param saveUrl  文件保存路径
     * @param fileName  文件名称
     * @throws IOException
     */
    public static void downloadPdf(String fileUrl, String saveUrl, String fileName) throws IOException {

        URL url = new URL(fileUrl);
        HttpURLConnection conn = (HttpURLConnection)url.openConnection();
        //设置超时间为3秒
        conn.setConnectTimeout(5*1000);
        //防止屏蔽程序抓取而返回403错误
        conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
        //得到输入流
        InputStream inputStream = conn.getInputStream();
        //获取自己数组
        byte[] getData = readInputStream(inputStream);
        //文件保存位置
        File saveDir = new File(saveUrl);
        if(!saveDir.exists()){
            saveDir.mkdir();
        }
        File file = new File(saveDir+File.separator+fileName);
        FileOutputStream fos = new FileOutputStream(file);
        fos.write(getData);
        if(fos!=null){
            fos.close();
        }
        if(inputStream!=null){
            inputStream.close();
        }
        System.out.println("info:"+url+" download success");

    }


    /**
     * 从输入流中获取字节数组
     * @param inputStream
     * @return
     * @throws IOException
     */
    public static  byte[] readInputStream(InputStream inputStream) throws IOException {
        byte[] buffer = new byte[1024];
        int len = 0;
        ByteArrayOutputStream bos = new ByteArrayOutputStream();
        while((len = inputStream.read(buffer)) != -1) {
            bos.write(buffer, 0, len);
        }
        bos.close();
        return bos.toByteArray();
    }


    /**
     * 下载pdf返回文件流
     * @param response 请求头
     * @param pdfName fileName
     * @param path    路径
     */
    public static void toDownload(HttpServletResponse response, String pdfName,String path)  {
        ServletOutputStream out = null;
        InputStream inputStream = null;

        try {
            // 获取外部文件流
            log.info("下载中------invPdfUrl=" +path);
            URL url = new URL(path);
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setConnectTimeout(3 * 1000);
            //防止屏蔽程序抓取而返回403错误
            conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
            inputStream = conn.getInputStream();
            /**
             * 输出文件到浏览器
             */
            int len = 0;
            // 输出 下载的响应头,如果下载的文件是中文名,文件名需要经过url编码
            response.setContentType("text/html;charset=utf-8");
            response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(pdfName, "UTF-8"));
            response.setHeader("Cache-Control", "no-cache");
            out = response.getOutputStream();
            byte[] buffer = new byte[1024];
            while ((len = inputStream.read(buffer)) > 0) {
                out.write(buffer, 0, len);
            }
            out.flush();
            log.info("pdf文件下载完成.....");
        } catch (Exception e) {

            log.error("pdf文件下载异常,e = {}", e);
            e.printStackTrace();
        } finally {
            if (inputStream != null) {
                try {
                    inputStream.close();
                } catch (Exception e) {
                }
            }
            if (out != null) {
                try {
                    out.close();
                } catch (Exception e) {
                }
            }
        }
    }




}

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要给前端返回 PDF 文件,可以使用 Java 中的 HttpServletResponse 对象来实现,具体步骤如下: 1. 设置响应头,告诉浏览器返回的是一个文件,而非普通的 HTML 页面: ```java response.setContentType("application/pdf"); response.setHeader("Content-Disposition", "attachment;filename=example.pdf"); ``` 2. 获取 PDF 文件的输入,可以从本地文件系统或者数据库中读取: ```java File file = new File("example.pdf"); InputStream inputStream = new FileInputStream(file); ``` 3. 将输入的内容写入响应输出中: ```java OutputStream outputStream = response.getOutputStream(); byte[] buffer = new byte[1024]; int len; while ((len = inputStream.read(buffer)) > 0) { outputStream.write(buffer, 0, len); } outputStream.flush(); outputStream.close(); inputStream.close(); ``` 至于如何在前端进行下载,可以在页面上添加一个下载按钮,点击后通过 JavaScript 代码发起下载请求。具体实现方法可以参考以下代码: ```javascript let xhr = new XMLHttpRequest(); xhr.open('GET', '/download/pdf', true); xhr.responseType = 'blob'; xhr.onload = function () { if (this.status === 200) { let blob = this.response; let a = document.createElement("a"); let url = window.URL.createObjectURL(blob); a.href = url; a.download = "example.pdf"; a.click(); window.URL.revokeObjectURL(url); } }; xhr.send(); ``` 以上代码中,我们通过 AJAX 发送 GET 请求,将响应类型设置为 blob,然后在 onload 回调函数中创建一个 a 标签,设置 href 属性为下载链接,download 属性为文件名,最后通过 a.click() 来触发下载

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值