vue項目中使用pdf.js預覽pdf文件(流)

好一段時間沒有來簡書寫東西了测垛,因為來到了平安銀行(橙信)工作了,工作也比較忙秧均,上班也沒得外網(wǎng)食侮,最近公司給配置了一個mac電腦,終于可以有外網(wǎng)權限了目胡,但還是有很多限制锯七,微信,百度云盤等等吧誉己,都用不了眉尸,
最近項目中需要顯示保險的電子保單,但給的地址是一個pdf文件流,遇到了各種問題效五,跨域地消、android手機打不開......,最終選擇了pdf.js插件畏妖,viewer.html?file=的形式打開脉执,下面詳情介紹一下開發(fā)步驟,
一戒劫、 首先是導入插件半夷,從官網(wǎng)直接下載,鏈接:官網(wǎng)直接下載迅细,在vue項目中巫橄,注意放在static文件目錄下

image.png

簡單介紹一下pdf.js目錄,核心的pdf.js和pdf.worker.js茵典,以及展示pdf的viewer.html頁面湘换,把它們作為靜態(tài)資源來編譯,基本想要的build和web這兩個重要文件夾的東西都正常編譯统阿。

二彩倚、重點介紹一下viewer.html?file=打開pdf文件
1、打開viewer.js看看

"use strict";
var DEFAULT_URL = 'compressed.tracemonkey-pldi-09.pdf';
var pdfjsWebApp = void 0;

里面有配置項扶平,DEFAULT_URL 是默認的pdf路徑帆离,繼續(xù)看源代碼,發(fā)現(xiàn)他可以通過file參數(shù)用來指定pdf的路徑


image.png

用viewer.html?file= 的方式结澄,我是iframe進行嵌套

<iframe :src="url" width="100%" height="100%"></iframe>

2哥谷、當viewer.html頁面的域和pdf文件域不一致的時候,會報 “file origin does not match viewer”錯誤麻献。 所以我們得改變一下源碼


image.png

3们妥、file=后面跟的pdf地址也有參數(shù),所以必須選擇 encodeURIComponent 進行對url的編碼

this.url = `${baseUrl.pageRoot}pdf/web/viewer.html?file=${encodeURIComponent(pdfUrl)}`

viewer.js里有方法parseQueryString(query)取到這個pdf文件地址后勉吻,會進行decodeURIComponent解碼

function parseQueryString(query) {
  var parts = query.split('&');
  var params = Object.create(null);
  for (var i = 0, ii = parts.length; i < ii; ++i) {
    var param = parts[i].split('=');
    var key = param[0].toLowerCase();
    var value = param.length > 1 ? param[1] : null;
    params[decodeURIComponent(key)] = decodeURIComponent(value);
  }
  return params;
}

4监婶、如果還是打不開pdf文件,pdf.js插件可能無法識別pdfUrl餐曼,所以的在最后加上 &.pdf 來騙過插件

Q: 目前還遇到一個問題,GET請求pdfUrl時鲜漩,cookie信息沒有帶給后端源譬,目前是讓后端直接屏蔽了登錄驗證,請各位指教孕似。GET請求源碼如下:

webViewerOpenFileViaURL = function webViewerOpenFileViaURL(file) {
    if (file && file.lastIndexOf('file:', 0) === 0) {
      PDFViewerApplication.setTitleUsingUrl(file);
      var xhr = new XMLHttpRequest();
      xhr.onload = function () {
        console.log('xhr onload() xhr.response = ' + xhr.response)
        PDFViewerApplication.open(new Uint8Array(xhr.response));
      };
      try {
        xhr.open('GET', file);
        xhr.responseType = 'arraybuffer';
        xhr.send();
      } catch (ex) {
        PDFViewerApplication.l10n.get('loading_error', null, 'An error occurred while loading the PDF.').then(function (msg) {
          console.log('line 2010 loading_error msg = ' + msg)
          PDFViewerApplication.error(msg, ex);
        });
      }
      return;
    }
    if (file) {
      PDFViewerApplication.open(file);
    }
  };

參考

如果項目中想用pdf.js或pdf.worker.js的外鏈可以參考:https://www.bootcdn.cn/pdf.js/

例如build/pdf.worker.js文件太大踩娘,可以修改web/viewer.js中的workerSrc路徑,改為對應版本的cdn地址即可

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市养渴,隨后出現(xiàn)的幾起案子雷绢,更是在濱河造成了極大的恐慌,老刑警劉巖理卑,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件翘紊,死亡現(xiàn)場離奇詭異,居然都是意外死亡藐唠,警方通過查閱死者的電腦和手機帆疟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宇立,“玉大人踪宠,你說我怎么就攤上這事÷栲冢” “怎么了柳琢?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長润脸。 經(jīng)常有香客問我柬脸,道長,這世上最難降的妖魔是什么津函? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任肖粮,我火速辦了婚禮,結果婚禮上尔苦,老公的妹妹穿的比我還像新娘涩馆。我一直安慰自己,他們只是感情好允坚,可當我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布魂那。 她就那樣靜靜地躺著,像睡著了一般稠项。 火紅的嫁衣襯著肌膚如雪涯雅。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天展运,我揣著相機與錄音活逆,去河邊找鬼。 笑死拗胜,一個胖子當著我的面吹牛蔗候,可吹牛的內容都是我干的。 我是一名探鬼主播埂软,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼锈遥,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起所灸,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤丽惶,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后爬立,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體钾唬,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年懦尝,在試婚紗的時候發(fā)現(xiàn)自己被綠了知纷。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡陵霉,死狀恐怖琅轧,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情踊挠,我是刑警寧澤乍桂,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站效床,受9級特大地震影響睹酌,放射性物質發(fā)生泄漏。R本人自食惡果不足惜剩檀,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一憋沿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧沪猴,春花似錦辐啄、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至担租,卻和暖如春砸民,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背奋救。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工岭参, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人尝艘。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓演侯,卻偏偏與公主長得像,于是被迫代替她去往敵國和親利耍。 傳聞我的和親對象是個殘疾皇子蚌本,可洞房花燭夜當晚...
    茶點故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)隘梨,斷路器程癌,智...
    卡卡羅2017閱讀 134,599評論 18 139
  • 1、通過CocoaPods安裝項目名稱項目信息 AFNetworking網(wǎng)絡請求組件 FMDB本地數(shù)據(jù)庫組件 SD...
    陽明先生_x閱讀 15,968評論 3 119
  • 今天晚上無意中翻網(wǎng)易新聞锐峭,里面提到了微軟的Hololens(Hololens技術,微軟已經(jīng)說了可婶,開發(fā)Hololen...
    Johnny_Chang閱讀 395評論 0 0
  • 每一場大雪沿癞,每一場雨,每一場離別矛渴,每一次背叛椎扬,每一次忘記,每一次心碎成粉末的心動與心悸具温。時間就像被蒸發(fā)的雨水一樣蚕涤,...
    敏敏金閱讀 214評論 0 0