Itext 7 - PdfReader 未使用所有者密码打开错误

Ahm*_*mad 7 c# asp.net pdf-generation pdf-reader itext7

我正在使用最新 Itext7 的此示例来填写文档,但收到此错误: iText.Kernel.Crypto.BadPasswordException: PdfReader 未使用所有者密码打开 在此输入图像描述 所以我环顾网络,发现有些人找到了解决此错误的方法 PdfReader.unethicalreading = true;,但是当我尝试使用相同的代码时,它说 PDFReader 中没有名为 unethicalreading 的定义

这是我的代码:

 string src = @"C:\test1.pdf";
    string dest = @"C:\Test2.pdf";
    PdfDocument pdfDoc = new PdfDocument(new PdfReader(src), new PdfWriter(dest));
    PdfAcroForm form = PdfAcroForm.GetAcroForm(pdfDoc, true);
    IDictionary<String, PdfFormField> fields = form.GetFormFields();
    PdfFormField toSet;
    fields.TryGetValue("Name", out toSet);
    toSet.SetValue("Some text");
Run Code Online (Sandbox Code Playgroud)

Bru*_*gie 9

您需要像这样更改您的代码:

string src = @"C:\test1.pdf";
string dest = @"C:\Test2.pdf";
PdfReader reader = new PdfReader(src);
reader.setUnethicalReading(true);
PdfDocument pdfDoc = new PdfDocument(reader, new PdfWriter(dest));
PdfAcroForm form = PdfAcroForm.GetAcroForm(pdfDoc, true);
IDictionary<String, PdfFormField> fields = form.GetFormFields();
PdfFormField toSet;
fields.TryGetValue("Name", out toSet);
toSet.SetValue("Some text");
Run Code Online (Sandbox Code Playgroud)

这将允许您违背文档原始作者定义的权限。这也证明设置此类权限已经过时,因为自从 PDF 成为 ISO 标准以来,不再有删除这些权限的惩罚。