С# iTextSharp Слияние нескольких PDF файлов через байтовый массив

Я новичок в использовании iTextSharp и работает с файлами Pdf в целом, но я думаю, что я на правильном пути.

Я перебираю список файлов PDF, конвертирую их в байты и выталкиваю все полученные байты в массив байтов. Оттуда я передаю массив байтов в concatAndAddContent(), чтобы объединить весь PDF файл в один большой pdf файл. В настоящее время я просто получаю последний pdf файл в списке (они, похоже, переписываются)

public static byte[] concatAndAddContent(List<byte[]> pdfByteContent)
    {
        byte[] allBytes;

        using (MemoryStream ms = new MemoryStream())
        {
            Document doc = new Document();
            PdfWriter writer = PdfWriter.GetInstance(doc, ms);

            doc.SetPageSize(PageSize.LETTER);
            doc.Open();
            PdfContentByte cb = writer.DirectContent;
            PdfImportedPage page;

            PdfReader reader;
            foreach (byte[] p in pdfByteContent)
            {
                reader = new PdfReader(p);
                int pages = reader.NumberOfPages;

                // loop over document pages
                for (int i = 1; i <= pages; i++)
                {
                    doc.SetPageSize(PageSize.LETTER);
                    doc.NewPage();
                    page = writer.GetImportedPage(reader, i);
                    cb.AddTemplate(page, 0, 0);

                }
            }

            doc.Close();
            allBytes = ms.GetBuffer();
            ms.Flush();
            ms.Dispose();
        }

        return allBytes;
    }

Выше приведен рабочий код, в результате которого создается один PDF файл, а остальные файлы игнорируются. Любые предложения

Ответ 1

Это скорее всего версия С# кода Бруно здесь.

Это самый простой, безопасный и рекомендуемый способ слияния PDF файлов. Объект PdfSmartCopy способен обнаруживать избыточность в нескольких файлах, которые могут несколько раз уменьшить размер файла. Одна из перегрузок на нем принимает полный объект PdfReader, который может быть создан, но вы хотите.

public static byte[] concatAndAddContent(List<byte[]> pdfByteContent) {

    using (var ms = new MemoryStream()) {
        using (var doc = new Document()) {
            using (var copy = new PdfSmartCopy(doc, ms)) {
                doc.Open();

                //Loop through each byte array
                foreach (var p in pdfByteContent) {

                    //Create a PdfReader bound to that byte array
                    using (var reader = new PdfReader(p)) {

                        //Add the entire document instead of page-by-page
                        copy.AddDocument(reader);
                    }
                }

                doc.Close();
            }
        }

        //Return just before disposing
        return ms.ToArray();
    }
}