我正在使用itext读取大型pdf文件并保存所选页面。
PdfReader reader = null;
reader = new PdfReader("customPath/largePdf.pdf");
int pages = reader.getNumberOfPages();
List<Integer> pagesList = new ArrayList<Integer>();
pagesList.add(1);
pagesList.add(2);
reader.selectPages(pagesList);
String path;
PdfStamper stamper = null;
path = String.format("customerPath/split.pdf");
stamper = new PdfStamper(reader, new FileOutputStream(path));
到目前为止一切都很好,我可以打开split.pdf。
现在,而不是保存到文件,我想将其保存到字节数组(以便以后可以将其保存为Blob)
尝试过此:
PdfReader reader = null;
reader = new PdfReader("customPath/largePdf.pdf");
int pages = reader.getNumberOfPages();
List<Integer> pagesList = new ArrayList<Integer>();
pagesList.add(1);
pagesList.add(2);
reader.selectPages(pagesList);
ByteArrayOutputStream baos = new ByteArrayOutputStream();
PdfStamper stamper2 = new PdfStamper(reader, baos);
byte[] byteARy = baos.toByteArray();
只是为了确保它能正常工作,我尝试将此字节数组写入文件:
OutputStream out = new FileOutputStream("customPath/fromByteArray.pdf");
out.write(byteARy);
out.close();
fromByteArray.pdf无法打开,并且大小为零,知道什么地方可能是错的吗?
创建baos.toByteArray()
后立即检索字节数组(使用PdfStamper
。
PdfStamper stamper2 = new PdfStamper(reader, baos);
byte[] byteARy = baos.toByteArray();
当时输出中没有(旁边)任何内容。相反,您必须等到关闭PdfStamper
之后才能检索输出。
PdfStamper stamper2 = new PdfStamper(reader, baos);
...
stamper2.close();
byte[] byteARy = baos.toByteArray();
现在字节数组应包含完整的带标记的PDF。