通过pdf的url在线浏览pdf

通过java controller将pdf下载到web系统中
package com.example.getorder.Controller;

import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import sun.misc.BASE64Decoder;

import javax.servlet.http.HttpServletRequest;
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;

@Controller
@RequestMapping("text")
public class TestController {


    @ResponseBody
    @RequestMapping("test")
    public String getStream(String uri,HttpServletRequest request) {

        try {
           String savePath=  downLoadFromUrl(request,uri);
           return savePath;
        }catch (Exception e)
        {
            e.printStackTrace();
        }

        return "";
    }

    /**
     * 从网络Url中下载文件
     * @param urlStr
     * @throws IOException
     */
    public static String  downLoadFromUrl(HttpServletRequest request, String urlStr) throws IOException{
        URL url = new URL(urlStr);
        HttpURLConnection conn = (HttpURLConnection)url.openConnection();
        //设置超时间为3秒
        conn.setConnectTimeout(3*1000);
        //防止屏蔽程序抓取而返回403错误
        conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");

        //得到输入流
        InputStream inputStream = conn.getInputStream();
        //获取自己数组
        byte[] getData = readInputStream(inputStream);
        String basePath="/WEB-INF/pdfjs/web";
        String path = request.getSession().getServletContext().getRealPath(basePath);
       // String savePath=TestController.class.getClassLoader().getResource("").getPath();
        //文件保存位置
        File saveDir = new File(path);
        if(!saveDir.exists()){
            saveDir.mkdir();
        }
        File file = new File(saveDir+File.separator+"dingdan.pdf");
        FileOutputStream fos = new FileOutputStream(file);
        fos.write(getData);
        if(fos!=null){
            fos.close();
        }
        if(inputStream!=null){
            inputStream.close();
        }

        return path+"dingdan.pdf";

     //   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.js将下载到本地的pdf文件打开 。用
<a href="#" οnclick="window.open('<%=basePath%>pdfjs/web/viewer.html?file=/pdfjs/web/dingdan.pdf','PDF','width:50%;height:50%;top:100;left:100;');">查看pdf</a> 即可
当然可以,通过URL直接访问PDF文件时添加水印通常是通过服务器端处理的。因为浏览器本身并不支持直接在PDF文件上添加注释或水印。以下是常见的流程: 1. **前端请求**:客户端(例如HTML页面)发送一个GET请求到包含PDF的服务器地址,同时传递可能的水印信息作为参数。 ```javascript fetch(`your-server-url?watermark=YourText`) .then(response => response.blob()) .then(blob => URL.createObjectURL(blob)) .then(pdfUrl => { // 在这里处理PDF URL并显示在iframe或PDF Viewer组件中 document.getElementById('pdf-container').src = pdfUrl; }); ``` 2. **后端处理**:在服务器端,你可以选择使用Node.js、Python或其他语言的库(如`pdfreactor`、`puppeteer`),对PDF文件进行操作,然后加入水印。然后将处理后的PDF文件作为响应返回给客户端。 ```javascript (server-side) const puppeteer = require('puppeteer'); app.get('/pdf/:id', async (req, res) => { const { id, watermark } = req.query; const browser = await puppeteer.launch(); const page = await browser.newPage(); // 打开原始PDF await page.goto(`https://example.com/original_pdf/${id}`); // 添加水印 await page.pdf({ path: 'temp.pdf', format: 'letter', printBackground: true, watermark: watermark }); // 返回新的PDF URL const outputUrl = `http://localhost/downloads/temp.pdf`; res.send(outputUrl); browser.close(); }); ``` 3. **渲染PDF**:客户端接收到服务器返回的新PDF URL后,将其嵌入到iframe或PDF查看器中,用户便能看到带有水印的PDF了。 请注意,这种方法涉及到了两个服务器请求和文件转换,所以性能可能会受到一定影响,特别是对于大文件或高并发的情况。如果你希望减少网络交互,可以在服务端存储已经处理过的带有水印的PDF文件,这样就只需要一个请求就能获取了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值