如何通过c#.net中的itextsharp使版本兼容
我想通过itextsharp dll(ver 5.0.5)创建一个可下载的pdf文件。 我有四个文本框,由用户填写并点击下载pdf文件。 填充文本粘贴在现有PDF文件的特定位置并使其可下载。 用户可以打开或保存该文件。 我的代码来创建一个文件是:
using iTextSharp.text; using iTextSharp.text.pdf; Response.Clear(); Response.ContentType = "application/pdf"; Response.AddHeader("Content-Disposition", "attachment;filename=Patient Refund Request " + txtPatientName.Text + ".pdf"); string sourceFile = Server.MapPath("~/Forms/Refund.pdf"); PdfReader reader = new PdfReader(sourceFile); iTextSharp.text.Rectangle size = reader.GetPageSizeWithRotation(1); Document document = new Document(size); PdfWriter writer = PdfWriter.GetInstance(document, Response.OutputStream); document.Open(); PdfContentByte cb = writer.DirectContent; BaseFont bf = BaseFont.CreateFont(BaseFont.HELVETICA_BOLD, BaseFont.CP1252, BaseFont.EMBEDDED); cb.SetColorFill(BaseColor.DARK_GRAY); cb.SetFontAndSize(bf, 12); cb.BeginText(); cb.ShowTextAligned(0, txtDate.Text, 260, 655, 0); cb.EndText(); cb.BeginText(); cb.ShowTextAligned(0, txtPatientName.Text, 260, 620, 0); cb.EndText(); cb.BeginText(); cb.ShowTextAligned(0, txtPatDOB.Text, 260, 588, 0); cb.EndText(); cb.BeginText(); ColumnText ct = new ColumnText(cb); ct.SetSimpleColumn(new Phrase(new Chunk(txtDescription.Text, FontFactory.GetFont(FontFactory.HELVETICA, 12, Font.BOLD))), 90, 440, 550, 36, 20, Element.ALIGN_LEFT | Element.ALIGN_TOP); ct.Go(); cb.EndText(); PdfImportedPage page = writer.GetImportedPage(reader, 1); cb.AddTemplate(page, 0, 0); document.Close(); writer.Close(); reader.Close();
此代码工作正常,打开PDF文件并显示所有内容。 我的问题是,这个pdf只在Adobe Reader 9或更高版本中打开。 它不是以较低版本打开的,例如Adobe Reader 6或7。我已经在Adobe Acrobat 7.0中打开它。 但它不能公开。 我公司的所有用户都有adobe acrobat 6或7。
我怎样才能使这个代码版本兼容,这个可下载的文件可以通过每个版本的最低版本6打开。我希望这些信息足以让你知道。 请给出总和建议或代码。
提前致谢
iText和iTextSharp的默认版本是PDF 1.4
,它应该与Adobe Acrobat 5兼容,所以我不确定为什么你在6和7有问题。但是如果你想改变版本,你可以这样做办法:
writer.PdfVersion = PdfWriter.VERSION_1_2;
我建议在创建writer
对象后立即设置它。
上一篇: How to make version compatible of a pdf file through itextsharp in c#.net
下一篇: Inconsistency in file before and after upload to Oracle DB