diff --git a/src/core/obj.js b/src/core/obj.js index b7565b7b0..66af45c95 100644 --- a/src/core/obj.js +++ b/src/core/obj.js @@ -1836,14 +1836,13 @@ var XRef = (function XRefClosure() { } } // reading XRef streams - var i, ii; - for (i = 0, ii = xrefStms.length; i < ii; ++i) { + for (let i = 0, ii = xrefStms.length; i < ii; ++i) { this.startXRefQueue.push(xrefStms[i]); this.readXRef(/* recoveryMode */ true); } // finding main trailer let trailerDict; - for (i = 0, ii = trailers.length; i < ii; ++i) { + for (let i = 0, ii = trailers.length; i < ii; ++i) { stream.pos = trailers[i]; const parser = new Parser({ lexer: new Lexer(stream), @@ -1861,18 +1860,26 @@ var XRef = (function XRefClosure() { continue; } // Do some basic validation of the trailer/root dictionary candidate. - let rootDict; try { - rootDict = dict.get("Root"); + const rootDict = dict.get("Root"); + if (!(rootDict instanceof Dict)) { + continue; + } + const pagesDict = rootDict.get("Pages"); + if (!(pagesDict instanceof Dict)) { + continue; + } + const pagesCount = pagesDict.get("Count"); + if (!Number.isInteger(pagesCount)) { + continue; + } + // The top-level /Pages dictionary isn't obviously corrupt. } catch (ex) { if (ex instanceof MissingDataException) { throw ex; } continue; } - if (!isDict(rootDict) || !rootDict.has("Pages")) { - continue; - } // taking the first one with 'ID' if (dict.has("ID")) { return dict; diff --git a/test/pdfs/issue12402.pdf.link b/test/pdfs/issue12402.pdf.link new file mode 100644 index 000000000..d974b03e1 --- /dev/null +++ b/test/pdfs/issue12402.pdf.link @@ -0,0 +1 @@ +https://github.com/mozilla/pdf.js/files/5597129/issue12402.pdf diff --git a/test/test_manifest.json b/test/test_manifest.json index 935427136..3336b8e34 100644 --- a/test/test_manifest.json +++ b/test/test_manifest.json @@ -842,6 +842,15 @@ "link": false, "type": "eq" }, + { "id": "issue12402", + "file": "pdfs/issue12402.pdf", + "md5": "70031cf610e24cc7164fb6ecd6980c8e", + "rounds": 1, + "link": true, + "firstPage": 8, + "lastPage": 8, + "type": "eq" + }, { "id": "issue10004", "file": "pdfs/issue10004.pdf", "md5": "64d1853060cefe3be50e5c4617dd0505",