iTextSharp不会复制数字签名

本文关键字:数字签名 复制 iTextSharp | 更新日期: 2023-09-27 18:00:39

我有一种方法,可以将多个页面的pdf拆分为每个页面的多个文件。我注意到,如果pdf包含数字签名或形状(例如矩形),iTextsharp不会将这些内容复制到拆分的文件中。这有什么原因吗?我是不是遗漏了什么?

 private static void MultipleSplitPdf(IResult result, List<string> fileNames, string directoryforsplit, out List<string> outFileNames)
    {
    if (fileNames.Count == 0)
    {
        result.SetError("no files!");
        outFileNames = null;
        return;
    }
    else
    {
        try
        {
            outFileNames = new List<string>();
            if (FileManager.DeleteDir(result, directoryforsplit) == false)
                return;
            DirectoryInfo dirInfo;
            if (FileManager.GetDirectory(result, directoryforsplit, out dirInfo) == false)
                return;
            int counter = 1;
            foreach (string fileName in fileNames)
            {
                // we create a reader for a certain document
                PdfReader reader = new PdfReader(fileName);
                // we retrieve the total number of pages
                int n = reader.NumberOfPages;
                //Console.WriteLine("There are " + n + " pages in the original file.");
                int pagenumber = n;
                //if (pagenumber == 1)
                //{
                //    FileInfo a = new FileInfo(fileName);
                //    a.CopyTo(directoryforsplit);
                //}
                //else
                    for (int i = 1; i <= pagenumber; i++)
                    {
                        iTextSharp.text.Document document1 = new iTextSharp.text.Document(reader.GetPageSizeWithRotation(i));
                        string splittedFilePath = directoryforsplit + "''Split" + counter.ToString() + ".pdf";
                        PdfWriter writer1 = PdfWriter.GetInstance(document1, new FileStream(splittedFilePath, FileMode.Create));
                        document1.Open();
                        PdfContentByte cb1 = writer1.DirectContent;
                        PdfImportedPage page;
                        int rotation;
                        document1.SetPageSize(reader.GetPageSizeWithRotation(i));
                        document1.NewPage();
                        page = writer1.GetImportedPage(reader, i);
                        rotation = reader.GetPageRotation(i);
                        if (rotation == 90 || rotation == 270)
                        {
                            cb1.AddTemplate(page, 0, -1f, 1f, 0, 0, reader.GetPageSizeWithRotation(i).Height);
                        }
                        else
                        {
                            cb1.AddTemplate(page, 1f, 0, 0, 1f, 0, 0);
                        }
                        counter++;
                        document1.Close();
                    }
            }
            // step 1: creation of a document-object
            //iTextSharp.text.Document document2 = new iTextSharp.text.Document(reader.GetPageSizeWithRotation(pagenumber));
            // step 2: we create a writer that listens to the document
            //PdfWriter writer2 = PdfWriter.GetInstance(document2, new FileStream(args[2], FileMode.Create));
            // step 3: we open the document
            //document2.Open();
            //PdfContentByte cb2 = writer2.DirectContent;

            // step 4: we add content
            //while (i < pagenumber - 1)
            //{
            //}
            //while (i < n)
            //{
            //    i++;
            //    document2.SetPageSize(reader.GetPageSizeWithRotation(i));
            //    document2.NewPage();
            //    page = writer2.GetImportedPage(reader, i);
            //    rotation = reader.GetPageRotation(i);
            //    if (rotation == 90 || rotation == 270)
            //    {
            //        cb2.AddTemplate(page, 0, -1f, 1f, 0, 0, reader.GetPageSizeWithRotation(i).Height);
            //    }
            //    else
            //    {
            //        cb2.AddTemplate(page, 1f, 0, 0, 1f, 0, 0);
            //    }
            //    Console.WriteLine("Processed page " + i);
            //}
            //// step 5: we close the document
            //document2.Close();
            FileInfo[] wordFiles = dirInfo.GetFiles();
            foreach (var item in wordFiles.OrderBy(i => i.LastWriteTime))
                outFileNames.Add(dirInfo.FullName + "''" + item.Name);
        }
        catch (Exception e)
        {
            outFileNames = null;
            result.SetError(e.Message + "'n" + e.StackTrace);
            return;
        }
    }
}

iTextSharp不会复制数字签名

  1. 你做错了!请阅读iText in Action的第6章,您会发现应该使用PdfStamperPdfCopyNOTDocument/PdfWriter的组合来拆分或合并文档如文档所示,您的代码将删除所有交互式功能请参阅如何正确合并文档?并阅读文档!这本书是免费的:关于StackOverflow的最佳iText问题
  2. 您的PDF文档是经过数字签名的。这意味着您无法从中提取页面,并且在不破坏数字签名的情况下,您无法将其与另一个文档合并。阅读如何使用java在数字签名pdf中添加空白页?找出你设计中的错误。您正在尝试做一些未完成的事情(通常,不限于iText或iTextSharp)