0.
A.到官网 https://mozilla.github.io/pdf.js/getting_started/#download 下载最新版本
B 部署到IIS 中访问 pdf.js/web/viewer.html 查看效果
1. 后台返回pdf的base64字段,用pdf.js展示
https://www.jianshu.com/p/8fb76e21b05e
2. 在线查看PDF文件,pdf.js使用方法
https://www.cnblogs.com/zhanggf/p/8504317.html
3.官方实例
https://github.com/mozilla/pdf.js/tree/master/examples/learning
_______________________________________________________________________________________________
大部分都是关于引入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:又称类型化数组。
- 数组里面可以放数字、字符串、布尔值以及对象和数组等,ArrayBuffer放0和1组成的二进制数据
- 数组放在堆中,ArrayBuffer则把数据放在栈中(所以取数据时后者快)
- ArrayBuffer初始化后固定大小,数组则可以自由增减。(准确的说,视图才应该跟数组来比较这个特点)
测试通的 base64 >> PDF 操作
<!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="jquery-1.10.2.js"></script> <script src="../build/pdf.js"></script> <script src="../build/pdf.worker.js"></script> <script> /*将请求来的base64编码的pdf文件,替换多余的空格和换行(为了兼容其他浏览器) * 再使用浏览器自带的atob()的方式解析 * */ /*转化编码格式*/ function converData(data) { data = data.replace(/[\n\r]/g, ''); var raw = window.atob(data); var rawLength = raw.length; var array = new Uint8Array(new ArrayBuffer(rawLength)); for (var i = 0; i < rawLength; i++) { array[i] = raw.charCodeAt(i) } return array } /*将解码后的值传给pdfjsLib.getDocument(),交给pdf.js处理*/ var loadtask=null; function showPdfFile(data) { var fileContent = converData(data); $('#container').show(); $('#pop').empty(); loadtask=pdfjsLib.getDocument(fileContent); loadtask.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('', i, id); } }) } function showAll(url, i, id) { loadtask.promise.then(function getPdfHelloWorld(pdf) { pdf.getPage(i).then(function getPageHelloWorld(page) { var scale = 2.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); }) }) } dataParameters={}; $.ajax({ url: 'http://localhost:20737/wind.CloudFile.Web/Home/Base64', type: "post", dataType: "json", data: dataParameters, beforeSend: function () { // addLoadingEle(); }, success: function (data) { console.log( 'msg:'+ JSON.stringify(data)); showPdfFile(data.Data); }, complete:function(data){ // removeLoadingEle(); }, error: function (a) { console.log(a); } }); </script> </body> </html>