Powershell itextSharp PDF打中文水印

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Powershell itextSharp PDF打中文水印相关的知识,希望对你有一定的参考价值。

参考技术A ## PDF Add WaterMark

[void][System.Reflection.Assembly]::LoadFile($itextSharpDllPath);

$pdfReader = [iTextSharp.text.pdf.PdfReader]::new($sOriPdfPath);

$stream = [System.IO.FileStream]::new($sTempWaterMarkPath + "\" + $sOriPdfName, [System.IO.FileMode]::Create, [System.IO.FileAccess]::Write);

$pdfStamper = [iTextSharp.text.pdf.PdfStamper]::new($pdfReader, $stream);

for($i = 0; $i -lt $pdfStamper.Reader.NumberOfPages; $i++)

    $pdfData = $pdfStamper.GetOverContent($i + 1);

    # simfang.ttf  STFANGSO.TTF  simkai.ttf

    $bfChinese = [iTextSharp.text.pdf.BaseFont]::CreateFont($sFontTTF, [iTextSharp.text.pdf.BaseFont]::IDENTITY_H, [iTextSharp.text.pdf.BaseFont]::NOT_EMBEDDED);

    $pdfData.BeginText();

    $pdfData.SetFontAndSize($bfChinese, 11);

    $pdfData.SetColorFill([iTextSharp.text.pdf.CMYKColor]::DARK_GRAY);   

    #$pdfData.ShowTextAligned([iTextSharp.text.pdf.PdfContentByte]::ALIGN_CENTER, $sWaterMatkText, $pdfStamper.Reader.GetPageSize(1).Width / 2, $pdfStamper.Reader.GetPageSize(1).Height / 2, $strRotation);   

    $rect = $pdfReader.GetPageSizeWithRotation($i + 1);

    $x = ($rect.Right + $rect.Left) / 2;

    $y = ($rect.Top + $rect.Bottom) / 2;   

    $pdfData.ShowTextAligned([iTextSharp.text.Element]::ALIGN_CENTER, $sWaterMatkText, $x, $y, $strRotation);     

    $pdfData.EndText();



$pdfStamper.Close();

$stream.Close();

$pdfReader.Close();

搞了一日,最后MAK哥帮手,原来是要求出GetPageSizeWithRotation,因为PDF的X和Y是调转的。

iTextSharp 正在生成损坏的 PDF

【中文标题】iTextSharp 正在生成损坏的 PDF【英文标题】:iTextSharp is producing a corrupt PDF 【发布时间】:2011-09-16 11:31:10 【问题描述】:

下面的代码 sn-p 返回一个损坏的 PDF 文档,但是如果我返回 mergeDocument,它总是返回一个有效的 PDF。 mergeDocument 是基于我使用 Word 创建的 PDF 文件,而完成的文档是完全以编程方式生成的。代码“有效”,因为它不会引发异常。为什么 iTextSharp 创建损坏的 PDF?

byte[] completedDocument = null;            
using (MemoryStream streamCompleted = new MemoryStream())

    using (Document document = new Document())
                        
        PdfCopy copy = new PdfCopy(document, streamCompleted);
        document.Open();
        copy.Open();                    

        foreach (var item in eventItems)
        
            byte[] mergedDocument = null;
            PdfReader reader = new PdfReader(pdfTemplates[item.DataTokens[NotifyTokenType.OrganisationID]]);
            using (MemoryStream streamTemplate = new MemoryStream())
            
                using (PdfStamper stamper = new PdfStamper(reader, streamTemplate))
                
                    foreach (var token in item.DataTokens)
                    
                        if (stamper.AcroFields.Fields.Any(fld => fld.Key == token.Key.ToString()))
                        
                            stamper.AcroFields.SetField(token.Key.ToString(), token.Value);
                        
                    
                    stamper.FormFlattening = true;
                    stamper.Writer.CloseStream = false;
                

                mergedDocument = new byte[streamTemplate.Length];
                streamTemplate.Position = 0;
                streamTemplate.Read(mergedDocument, 0, (int)streamTemplate.Length);
            
            reader = new PdfReader(mergedDocument);

            for (int i = 1; i <= reader.NumberOfPages; i++)
            
                document.SetPageSize(PageSize.A4);
                copy.AddPage(copy.GetImportedPage(reader, i));
            
        
        completedDocument = new byte[streamCompleted.Length];
        streamCompleted.Position = 0;
        streamCompleted.Read(completedDocument, 0, (int)streamCompleted.Length);
                    

return completedDocument;

【问题讨论】:

【参考方案1】:

您需要关闭 documentcopy 对象以刷新 PDF 写入缓冲区。但是,这在尝试将流读入数组时会导致一些问题。解决方法是使用MemoryStreamToArray() 方法,它仍然适用于封闭的流。我所做的更改上有 cmets。

        byte[] completedDocument = null;
        using (MemoryStream streamCompleted = new MemoryStream())
        
            using (Document document = new Document())
            
                PdfCopy copy = new PdfCopy(document, streamCompleted);
                document.Open();
                copy.Open();

                foreach (var item in eventItems)
                
                    byte[] mergedDocument = null;
                    PdfReader reader = new PdfReader(pdfTemplates[item.DataTokens[NotifyTokenType.OrganisationID]]);
                    using (MemoryStream streamTemplate = new MemoryStream())
                    
                        using (PdfStamper stamper = new PdfStamper(reader, streamTemplate))
                        
                            foreach (var token in item.DataTokens)
                            
                                if (stamper.AcroFields.Fields.Any(fld => fld.Key == token.Key.ToString()))
                                
                                    stamper.AcroFields.SetField(token.Key.ToString(), token.Value);
                                
                            
                            stamper.FormFlattening = true;
                            stamper.Writer.CloseStream = false;
                        
                        //Copy the stream's bytes
                        mergedDocument = streamTemplate.ToArray();
                    
                    reader = new PdfReader(mergedDocument);

                    for (int i = 1; i <= reader.NumberOfPages; i++)
                    
                        document.SetPageSize(PageSize.A4);
                        copy.AddPage(copy.GetImportedPage(reader, i));
                    
                    //Close the document and the copy
                    document.Close();
                    copy.Close();
                
                //ToArray() can operate on closed streams
                completedDocument = streamCompleted.ToArray();
            
        
        return completedDocument;

【讨论】:

如果可以的话,我会投票 1000 次。我在将图像和 pdf 合并为一个 pdf 文档时遇到了困难,这有助于阐明正确的过程。 谢谢,将内存流放入数组解决了我取回空 PDF 文件的问题!【参考方案2】:

在将 html 转换为 pdf 时,还要确保您的 html 不包含 hr 标签

hdnEditorText.Value.Replace("\"", "'").Replace("<hr />", "").Replace("<hr/>", "")

【讨论】:

以上是关于Powershell itextSharp PDF打中文水印的主要内容,如果未能解决你的问题,请参考以下文章

C#可以用itextsharp 打开PDF文件吗?

iTextSharp + FileStream = 损坏的 PDF 文件

使用 iTextSharp 裁剪 PDF

使用 itextsharp 获取 PDF 页面的缩略图

iTextSharp 正在生成损坏的 PDF

itextsharp去掉PDF加密