首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JAVA Merge 2 PDF字节数组

JAVA Merge 2 PDF字节数组
EN

Stack Overflow用户
提问于 2020-12-09 00:45:07
回答 1查看 1.9K关注 0票数 0

我收到两个PDF,每个都是一个字节数组。所以现在我有两个数组,a[]和b[]。我将它们连接起来并保存到c[]中。当我将c[]转换为PDF时,只显示了第二个文件。当我检查c[]的长度时,它是len(a[]) + len(b[])。

我找到了适用于不同编程语言的other questions,他们说我不能像这样将它们连接起来,我们需要使用一个PDF编写库。由于我首先接收字节数组,有没有其他方法可以在我的情况下工作?

EN

回答 1

Stack Overflow用户

发布于 2020-12-09 01:06:23

你不能仅仅连接字节数组。

你可以在这里找到几个合并How to merge two PDF files into one in Java?文件的解决方案

如果你有PDF文件,你可以使用pdfbox的PDFMergerUtility。

代码语言:javascript
复制
PDFMergerUtility ut = new PDFMergerUtility();
ut.addSource(...);
ut.addSource(...);
ut.addSource(...);
ut.setDestinationFileName(...);
ut.mergeDocuments();

如果PDF文件不可用,您可以只使用另一种解决方案

代码语言:javascript
复制
import com.itextpdf.text.Document;
import com.itextpdf.text.pdf.PdfContentByte;
import com.itextpdf.text.pdf.PdfImportedPage;
import com.itextpdf.text.pdf.PdfReader;
import com.itextpdf.text.pdf.PdfWriter;

/**
 * This class is used to merge two or more 
 * existing pdf file using iText jar.
 */
public class PDFMerger {

   static void mergePdfFiles(List<InputStream> inputPdfList,
                             OutputStream outputStream) throws Exception{
      //Create document and pdfReader objects.
      Document document = new Document();
      List<PdfReader> readers = 
              new ArrayList<PdfReader>();
      int totalPages = 0;

      //Create pdf Iterator object using inputPdfList.
      Iterator<InputStream> pdfIterator = 
          inputPdfList.iterator();

      // Create reader list for the input pdf files.
      while (pdfIterator.hasNext()) {
          InputStream pdf = pdfIterator.next();
          PdfReader pdfReader = new PdfReader(pdf);
          readers.add(pdfReader);
          totalPages = totalPages + pdfReader.getNumberOfPages();
      }

      // Create writer for the outputStream
      PdfWriter writer = PdfWriter.getInstance(document, outputStream);

      //Open document.
      document.open();

      //Contain the pdf data.
      PdfContentByte pageContentByte = writer.getDirectContent();

      PdfImportedPage pdfImportedPage;
      int currentPdfReaderPage = 1;
      Iterator<PdfReader> iteratorPDFReader = readers.iterator();

      // Iterate and process the reader list.
      while (iteratorPDFReader.hasNext()) {
        PdfReader pdfReader = iteratorPDFReader.next();
        //Create page and add content.
        while (currentPdfReaderPage <= pdfReader.getNumberOfPages()) {
              document.newPage();
              pdfImportedPage = 
              writer.getImportedPage(pdfReader,currentPdfReaderPage);
              pageContentByte.addTemplate(pdfImportedPage, 0, 0);
              currentPdfReaderPage++;
        }
        currentPdfReaderPage = 1;
     }

     //Close document and outputStream.
     outputStream.flush();
     document.close();
     outputStream.close();

     System.out.println("Pdf files merged successfully.");
   }

}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65203173

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档