我在itext 7中写了一些代码,用IRandomAccessSource加载大的PDF。
IRandomAccessSource rdSource = null;
File pdf = new File(folder, getFilename());
rdSource = new RandomAccessSourceFactory().createBestSource(pdf.getCanonicalPath());
pdfReader = new PdfReader(rdSource, null);
PdfDocument doc = new PdfDocument(pdfReader); // --> Throws NullPointerException with 7.1.11
如果调用PdfDocument doc = new PdfDocument(pdfReader),我会得到一个NullPointerException,因为我把Maven的依赖关系从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>
有什么提示,为什么新版本会出现这种情况?谢谢你的建议
Regards Michel
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;
显然,ReaderProperties需要在新版本中传递。我把代码改为
pdfReader = new PdfReader(rdSource, new ReaderProperties());
现在可以用了... 这怎么可能,在V.7.0.4时还能用,现在7.1.11就变了?
总之,问题解决了。问题解决了
祝贺