[
https://issues.apache.org/jira/browse/PDFBOX-4666?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16948184#comment-16948184
]
Tilman Hausherr commented on PDFBOX-4666:
-----------------------------------------
I need to think about this a bit, but it can be solved by checking whether the
actual resources object in {{DrawObject.process()}} is identical to the one of
{{context}}. This is not perfect, but it will catch this case, i.e. a direct
recursion.
> StackOverflowError with PDFTextStripper.getText()
> -------------------------------------------------
>
> Key: PDFBOX-4666
> URL: https://issues.apache.org/jira/browse/PDFBOX-4666
> Project: PDFBox
> Issue Type: Bug
> Affects Versions: 2.0.17
> Reporter: Josh Wein
> Priority: Major
> Attachments: example.pdf
>
>
> Reproducible with the attached file
>
> {code:java}
> File pdf = new File("example.pdf");
> PDDocument doc = PDDocument.load(pdf);
> new PDFTextStripper().getText(doc);
> {code}
>
> {code:java}
> java.lang.StackOverflowErrorjava.lang.StackOverflowError at
> java.util.zip.Inflater.<init>(Inflater.java:102) at
> org.apache.pdfbox.filter.FlateFilter.decompress(FlateFilter.java:74) at
> org.apache.pdfbox.filter.FlateFilter.decode(FlateFilter.java:50) at
> org.apache.pdfbox.filter.Filter.decode(Filter.java:87) at
> org.apache.pdfbox.cos.COSInputStream.create(COSInputStream.java:84) at
> org.apache.pdfbox.cos.COSStream.createInputStream(COSStream.java:175) at
> org.apache.pdfbox.cos.COSStream.createInputStream(COSStream.java:163) at
> org.apache.pdfbox.pdmodel.graphics.form.PDFormXObject.getContents(PDFormXObject.java:144)
> at
> org.apache.pdfbox.pdfparser.PDFStreamParser.<init>(PDFStreamParser.java:92)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStreamOperators(PDFStreamEngine.java:496)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStream(PDFStreamEngine.java:480)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.showForm(PDFStreamEngine.java:184)
> at
> org.apache.pdfbox.contentstream.operator.DrawObject.process(DrawObject.java:65)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processOperator(PDFStreamEngine.java:872)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStreamOperators(PDFStreamEngine.java:506)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStream(PDFStreamEngine.java:480)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.showForm(PDFStreamEngine.java:184)
> at
> org.apache.pdfbox.contentstream.operator.DrawObject.process(DrawObject.java:65)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processOperator(PDFStreamEngine.java:872)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStreamOperators(PDFStreamEngine.java:506)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStream(PDFStreamEngine.java:480)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.showForm(PDFStreamEngine.java:184)
> at
> org.apache.pdfbox.contentstream.operator.DrawObject.process(DrawObject.java:65)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processOperator(PDFStreamEngine.java:872)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStreamOperators(PDFStreamEngine.java:506)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStream(PDFStreamEngine.java:480)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.showForm(PDFStreamEngine.java:184)
> at
> org.apache.pdfbox.contentstream.operator.DrawObject.process(DrawObject.java:65)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processOperator(PDFStreamEngine.java:872)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStreamOperators(PDFStreamEngine.java:506)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStream(PDFStreamEngine.java:480)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.showForm(PDFStreamEngine.java:184)
> at
> org.apache.pdfbox.contentstream.operator.DrawObject.process(DrawObject.java:65)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processOperator(PDFStreamEngine.java:872)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStreamOperators(PDFStreamEngine.java:506)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStream(PDFStreamEngine.java:480)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.showForm(PDFStreamEngine.java:184)
> at
> org.apache.pdfbox.contentstream.operator.DrawObject.process(DrawObject.java:65)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processOperator(PDFStreamEngine.java:872)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStreamOperators(PDFStreamEngine.java:506)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStream(PDFStreamEngine.java:480)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.showForm(PDFStreamEngine.java:184)
> ...
> at
> org.apache.pdfbox.contentstream.operator.DrawObject.process(DrawObject.java:65)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processOperator(PDFStreamEngine.java:872)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStreamOperators(PDFStreamEngine.java:506)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processStream(PDFStreamEngine.java:480)
> at
> org.apache.pdfbox.contentstream.PDFStreamEngine.processPage(PDFStreamEngine.java:153)
> at
> org.apache.pdfbox.text.LegacyPDFStreamEngine.processPage(LegacyPDFStreamEngine.java:139)
> at
> org.apache.pdfbox.text.PDFTextStripper.processPage(PDFTextStripper.java:391)
> at
> org.apache.pdfbox.text.PDFTextStripper.processPages(PDFTextStripper.java:319)
> at org.apache.pdfbox.text.PDFTextStripper.writeText(PDFTextStripper.java:266)
> at
> org.apache.pdfbox.text.PDFTextStripper.getText(PDFTextStripper.java:227){code}
--
This message was sent by Atlassian Jira
(v8.3.4#803005)
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]