zoukankan      html  css  js  c++  java
  • base64编码后的pdf文件前端页面展示--pdf.js的应用

    最近在整理项目中用到的插件或者使用心得,感觉还是写成博客,能加深新一层的理解。

    我先说一下我的需求:由于java后台编译的文件流在手机端加载速度太慢,所以想着可以在前端解析,放在页面展示给用户。

    所以,我需要后台传给我的是base64编码的pdf文件。我们知道,单纯靠base64解析pdf文件是解析不了的。所以需要引入另一个pdf解析文件--pdf.js

    具体的使用方法大家可以看源码:https://mozilla.github.io/pdf.js/

    我试着按源码一步一步的操作的,但发现将build文件夹整体引入,也没有方法解决我的需求。最后,在项目中只引用了pdf.js和pdf.worker.js。引入方式和其他引入js文件一样。

    我将我自己的demo放在gitHub上了,有兴趣的可以看一下。这里,我先说一下我的理解。

    看了很多关于pdf.js的博客,大部分都是关于引入pdf的路径,然后在前端页面展示出来的。关于base64编码后的pdf文件很少。直接引入pdf文件路径的方法,我就不介绍了,大家可以参考其他博客。我现在介绍一下,经过base64编码后的pdf文件如何在前端页面显示出来。

    需要的知识点:大家需要知道 Unit8Array和arrayBuffer

    首先说一下Unit8Array:(具体可自己查一下MDN https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Uint8Array)

    Uint8Array 数组类型表示一个8位无符号整型数组,创建时内容被初始化为0。创建完后,可以以对象的方式或使用数组下标索引的方式引用数组中的元素。

                     语法结构:Uint8Array(length);//创建初始化为0的,包含length个元素的无符号整型数组

                                       Uint8Array(typedArray);

                                        Uint8Array(object);

              Uint8Array(buffer [, byteOffset [, length]]);

    ArrayBuffer:又称类型化数组
    1. 数组里面可以放数字、字符串、布尔值以及对象和数组等,ArrayBuffer放0和1组成的二进制数据
    2. 数组放在堆中,ArrayBuffer则把数据放在栈中(所以取数据时后者快)
    3. ArrayBuffer初始化后固定大小,数组则可以自由增减。(准确的说,视图才应该跟数组来比较这个特点)
    接下来,我贴一下代码
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>pdf的使用</title>
    </head>
    <body>
    <div id="container">
        <div id="pop"></div>
    </div>
    <script src="../js/pdf.js"></script>
    <script src="../js/pdf.worker.js"></script>
    <script>
        /*将请求来的base64编码的pdf文件,替换多余的空格和换行(为了兼容其他浏览器)
        * 再使用浏览器自带的atob()的方式解析
        * */
        /*转化编码格式*/
        function converData(data) {
            data = data.replace(/[
    
    ]/g, '');
            var raw = window.atob(data);
            var rawLength = raw.length;
            var array = new Unit8Array(new ArrayBuffer(rawLength));
            for (var i = 0; i < rawLength; i++) {
                array[i] = raw.charCodeAt(i)
            }
            return array
        }
    
        /*将解码后的值传给PDFJS.getDocument(),交给pdf.js处理*/
        function showPdfFile(data) {
            var fileContent = converData(data);
            $('#container').show();
            $('#pop').empty();
            PDFJS.getDocument(fileContent).then(function getPdfHelloWorld(pdf) {
                pages = pdf.numPages;
                for (var i = 1; i < pdf.numPages; i++) {
                    var id = 'page-id' + i;
                    $('#pop').append('<canvas id="' + id + '"></canvas>');
                    showAll(url, i, id)
                }
            })
        }
    
        function showAll(url, i, id) {
            PDFJS.getDocument().then(function getPdfHelloWorld(pdf) {
                pdf.getPage(page).then(function getPageHelloWorld(page) {
                    var scale = 1.0,
                        viewport = page.getViewport(scale),
                        canvas = document.getElementById(id),
                        context = canvas.getContext('2d');
                    canvas.height = viewport.height;
                    canvas.width = viewport.width;
                    var renderContext = {
                        canvasContext: context,
                        viewport: viewport
                    }
                    page.render(renderContext)
    
                })
    
            })
        }
    
    </script>
    </body>
    </html>
    

      

    
    
    
  • 相关阅读:
    sql: 左连接 和内连接区别联系 No
    Maven 浅谈一 No
    日记090212
    js 获取asp 控件DropDownList的选择值,及所有的text和value
    ASP.NET 2.0 只读 TextBox 回发后信息丢失
    Cry On My Shoulder (背景音乐)
    Inside ASP.NET 2.0 DataBound Control 3
    ASP.NET自定义控件复杂属性声明持久性浅析
    Inside ASP.NET 2.0 DataBound Control 2
    ASP.NET 2.0 Client Callback 浅析
  • 原文地址:https://www.cnblogs.com/bllx/p/9280912.html
Copyright © 2011-2022 走看看