使用PDF.JS实现PDF在线跨域预览功能

本文介绍了一种在Web应用中实现PDF文件在线预览的方法,包括将PDF文件通过相对路径或远程URL调用预览页面,以及后端如何处理URL转换成流输入,确保文件能正确加载。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.将所需的两个文件夹放入WEB目录下

2.

在前台调用VIEWER.HTML页面。

(1)若为本地文件,直接通过相对路径调用如:

window.open("../pages/web/viewer.html?file=./测试.pdf"); 

(2)若调用其他服务器的文件,则传入下载的URL地址(此地址直接输入浏览器应可直接下载文件)

window.open("../pages/web/viewer.html?file="+encodeURIComponent(ctxPre+"/user/salebybkdtl/convert1?filePath="+filePath)); 

需先通过后台将URL转换成流输入,后台代码如下:

 @ResponseBody
    @RequestMapping(value = "/convert1")
    @HeadInit(name = HeadConstants.HEAD_SCENE, value = "Cst")
    public String getPdfInfo(HttpServletRequest request, HttpServletResponse response, @RequestParam String filePath) throws IOException {
        String pdfUrl = filePath;
        URL url;
        try {
            url = new URL(pdfUrl);
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setConnectTimeout(5 * 1000);
            InputStream inputStream = conn.getInputStream();
            response.setHeader("Content-Disposition", "attachment;fileName=结业.pdf");
            response.setContentType("multipart/form-data");
            OutputStream outputStream = response.getOutputStream();
            IOUtils.write(IOUtils.toByteArray(inputStream), outputStream);
        } catch (MalformedURLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return null;
    }

 

IOUtils用的是org.apache.commons.io.IOUtils
最后感谢大佬https://blog.youkuaiyun.com/tao111369/article/details/79714154  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值