Проблема при переходе с itext 7.0.4 на 7.1.11 - PullRequest
1 голос
/ 07 мая 2020
• 1000 от 7.0.4 до 7.1.11
java.lang.NullPointerException
    at com.itextpdf.kernel.pdf.PdfDocument.open(PdfDocument.java:1867)
    at com.itextpdf.kernel.pdf.PdfDocument.<init>(PdfDocument.java:252)
    at com.itextpdf.kernel.pdf.PdfDocument.<init>(PdfDocument.java:234)
    at pdfTextExtractor.ValidateSendung.execute(ValidateSendung.java:68)
    at pdfTextExtractor.TestValidateSendunge.test2(TestValidateSendunge.java:36)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:89)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:41)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:541)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:763)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:463)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:209)

Зависимости Maven:

<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>kernel</artifactId>
    <version>7.1.11</version>
</dependency>
<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>io</artifactId>
    <version>7.1.11</version>
</dependency>
<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>layout</artifactId>
    <version>7.1.11</version>
</dependency> 

Любая подсказка, почему это происходит с новой версией? Спасибо

С уважением, Мишель

Method PDFDocument.open --> Crashes on 
 memoryLimitsAwareHandler = reader.properties.memoryLimitsAwareHandler;
as reader.properties is null

   protected void open(PdfVersion newPdfVersion) {
        this.fingerPrint = new FingerPrint();

        try {
            EventCounterHandler.getInstance().onEvent(CoreEvent.PROCESS, properties.metaInfo, getClass());
            if (reader != null) {
                if (reader.pdfDocument != null) {
                    throw new PdfException(PdfException.PdfReaderHasBeenAlreadyUtilized);
                }
                reader.pdfDocument = this;
                memoryLimitsAwareHandler = reader.properties.memoryLimitsAwareHandler;

1 Ответ

2 голосов
/ 07 мая 2020

Очевидно, что ReaderProperties необходимо передать в новой версии. Я изменил код на

pdfReader = new PdfReader(rdSource, new ReaderProperties());

И теперь он работает .. Как это может быть, что это работало в V.7.0.4, а теперь изменилось в 7.1.11?

Так или иначе : Проблема решена

С уважением

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...