4

这就是我想要做的:

  1. 使用 pdfbox 制作 2 个不同的 pdf 文件

  2. 使用 pdfmerger 将这两个文件合并在一起

如果我将#1 保存到服务器端本地硬盘驱动器并加载#2 的文件,我知道该怎么做。但我想做的是使用“直接从内存中”。我已经搜索了这个 pdfboxes 中的所有方法,但仍然找不到。

这是我从本地文件中获取的代码

谢谢你。

import java.io.BufferedOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;

import org.apache.pdfbox.exceptions.COSVisitorException;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.edit.PDPageContentStream;
import org.apache.pdfbox.pdmodel.font.PDFont;
import org.apache.pdfbox.pdmodel.font.PDTrueTypeFont;
import org.apache.pdfbox.pdmodel.font.PDType1Font;
import org.apache.pdfbox.util.PDFMergerUtility;

/**
* This is an example that creates a simple document
* with a ttf-font.
*
* @author <a href="mailto:m.g.n@gmx.de">Michael Niedermair</a>
* @version $Revision: 1.2 $
*/
public class Test2
{

    /**
    * create the second sample document from the PDF file format specification.
    *
    * @param file     The file to write the PDF to.
    * @param message    The message to write in the file.
    * @param fontfile  The ttf-font file.
    *
    * @throws IOException If there is an error writing the data.
    * @throws COSVisitorException If there is an error writing the PDF.
    */
    public void doIt(final String file, final String message) throws IOException, COSVisitorException
    {

        // the document
        PDDocument doc = null;
        try
        {
            doc = new PDDocument();

            PDPage page = new PDPage();
            doc.addPage(page);
            PDFont font = PDType1Font.HELVETICA_BOLD;


            PDPageContentStream contentStream = new PDPageContentStream(doc, page);
            contentStream.beginText();
            contentStream.setFont(font, 12);
            contentStream.moveTextPositionByAmount(100, 700);
            contentStream.drawString(message);
            contentStream.endText();
            contentStream.close();

            doc.save(file);

            System.out.println(file + " created!");
        }
        finally
        {
            if (doc != null)
            {
                doc.close();
            }
        }
    }

    /**
     * This will create a hello world PDF document
     * with a ttf-font.
     * <br />
     * see usage() for commandline
     *
     * @param args Command line arguments.
     */
    public static void main(String[] args)
    {

        Test2 app = new Test2();
        Test2 app2 = new Test2();
        try {
            app.doIt("C:/here.pdf", "hello");
            app2.doIt("C:/here2.pdf", "helloagain");
            PDFMergerUtility merger = new PDFMergerUtility();
            merger.addSource("C:/here.pdf");
            merger.addSource("C:/here2.pdf");
            OutputStream bout2 = new BufferedOutputStream(new FileOutputStream("C:/hereisthefinal.pdf"));

            merger.setDestinationStream(bout2);
            merger.mergeDocuments();

        } catch (COSVisitorException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}
4

4 回答 4

16

您只需要使用该PdfMergeUtility.addSource(InputStream)方法从输入流而不是物理文件添加源。

快速浏览一下 API,您可以做的是使用该PDDocument.save(OutputStream)方法将文件写入内存中的字节数组,这样应该可以工作。

static byte[] doIt(String message) {
   PDDocument doc = new PDDocument();
   // add the message
   ByteArrayOutputStream baos = new ByteArrayOutputStream();
   doc.save(baos);
   return baos.toByteArray();
}

void main(String args[]) {
   byte[] pdf1 = doIt("hello");
   byte[] pdf2 = doIt("world");
   PDFMergerUtility merger = new PDFMergerUtility();
   merger.addSource(new ByteArrayInputStream(pdf1));
   merger.addSource(new ByteArrayInputStream(pdf2));
   // do the rest with the merger
}
于 2012-12-10T19:59:48.230 回答
10

我使用它来合并一些文档(InputStreams)并将合并的文档写入 HttpServletResponse。

  PDFMergerUtility mergedDoc = new PDFMergerUtility();
  ByteArrayOutputStream colDocOutputstream = new ByteArrayOutputStream();

  for (int i = 0; i < documentCount; i++)
  {
    ByteArrayOutputStream tempZipOutstream = new ByteArrayOutputStream();
...
    mergedDoc.addSource(new ByteArrayInputStream(tempZipOutstream.toByteArray()));
  }

  mergedDoc.setDestinationStream(colDocOutputstream);
  mergedDoc.mergeDocuments();

  response.setContentLength(colDocOutputstream.size());
  response.setContentType("application/pdf");
  response.setHeader("Content-Disposition", "attachment; filename=mergedDocument.pdf");
  response.setHeader("Pragma", "public");
  response.setHeader("Cache-Control", "max-age=0");
  response.addDateHeader("Expires", 0);
  response.getOutputStream().write(colDocOutputstream.toByteArray());
于 2013-02-19T07:24:34.887 回答
2

您也可以使用这种方式:-
1) 创建 InputStream 列表
2) 实例化 PDFMergerUtility 类
3) 设置目标输出流
4) 将所有 InputStreams 添加到 PDFMerger 作为需要合并的源文件。5)通过调用“ ”
合并文档PDFmerger.mergeDocuments();

   List<InputStream> locations=new ArrayList<InputStream>();
        locations.add(new FileInputStream("E:/Filenet Project Support/MergePDFs_Sample_Code/Attorney_new_form.pdf"));
        locations.add(new FileInputStream("E:/Filenet Project Support/MergePDFs_Sample_Code/JH.pdf"));
        locations.add(new FileInputStream("E:/Filenet Project Support/MergePDFs_Sample_Code/Interpreter_new_form.pdf"));
        //Instantiating PDFMergerUtility class
        PDFMergerUtility PDFmerger = new PDFMergerUtility();
        //Setting Destination Output Stream
        OutputStream out = new FileOutputStream("E:/Filenet Project Support/MergePDFs_Sample_Code/merged.pdf");
        //Adding all InputStreams to PDFMerger as Source files which needs to be merged.
        PDFmerger.addSources(locations);
        //Setting Destination Output Stream
        PDFmerger.setDestinationStream(out);
        //Merging the two documents
        PDFmerger.mergeDocuments();
        System.out.println("Documents merged");
于 2017-05-09T05:08:43.913 回答
1

使用 REST 和 PDFBOX

@RequestMapping(value = "/getMergePdf", method = RequestMethod.GET)
    public ResponseEntity<byte[]> getMergePdf(@RequestParam(value = "filePath", required = true) String filePath,
            @RequestParam(value = "newFileName", required = true) String newFileName) throws IOException {

            // Step 1: Loading an Existing PDF Document
        File file = new File(filePath);
        File[] listFile = file.listFiles();

        // Step 2: Instantiating the PDFMergerUtility class
        PDFMergerUtility mergePdf = new PDFMergerUtility();

        // Step 3: Setting the source files
        for (File pdfName : listFile) {
            mergePdf.addSource(pdfName);
        }

        // Step 4: Setting the destination file
        ByteArrayOutputStream pdfDocOutputstream = new ByteArrayOutputStream();
        mergePdf.setDestinationFileName(newFileName + ".pdf");
        mergePdf.setDestinationStream(pdfDocOutputstream);
        mergePdf.mergeDocuments(MemoryUsageSetting.setupTempFileOnly());

        // Step 5: write in Response
        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_PDF);

        // Here you have to set the actual filename of your pdf
        headers.setContentDispositionFormData(mergePdf.getDestinationFileName(), mergePdf.getDestinationFileName());
        headers.setCacheControl("must-revalidate, post-check=0, pre-check=0");
        ResponseEntity<byte[]> response = new ResponseEntity<>(pdfDocOutputstream.toByteArray(), headers, HttpStatus.OK);
        return response;


    }
于 2019-10-19T12:24:40.920 回答