0

我需要打印一个我已更改的 pdf 文档,而不将其保存为新的 pdf 文档。下面的代码可以正常工作。但是,我想以完全不同的方式做到这一点,并且我同时有大脑滞后并且看不到解决方案。

我的代码示例

byte[] result;

using (MemoryStream ms = new MemoryStream())
{
    PdfReader pdfReader = new PdfReader("c:\\templatePdf.pdf");
    PdfStamper pdfStamper = new PdfStamper(pdfReader, ms);

    /* abbreviated but here I alter the template pdf */

    pdfStamper.FormFlattening = true;
    pdfStamper.Close();
    result = ms.GetBuffer();
}

/* Instead of saving a new file I would rather like to print
   the altered template pdf in memory and then discard it */
using (FileStream fs = File.Create("C:\\Test.pdf"))
{
    fs.Write(result, 0, (int)result.Length);
}

Process process = new Process();
process.StartInfo.FileName = "C:\\Test.pdf";
process.StartInfo.Verb = "printto";
process.StartInfo.Arguments = "\"" + ppr_PrinterDropDown.Text + "\"";
process.Start();
File.Delete("C:\\Test.pdf");
4

3 回答 3

1

如果您使用的是基于文件的 API,那么在没有文件的情况下您将很难做到。您也许可以设置一个命名管道服务器,但坦率地说,这是一个巨大的小提琴。但是,我很想四处寻找具有打印支持的完全托管的 PDF 库。但最终......文件系统真的有什么危害?可能不会很多。不过,我可能会建议一些调整:

  1. 使用临时区域 ( Path.GetTempPath()),而不是C:\Test
  2. 在删除文件之前等待该过程完成
于 2013-01-17T23:18:36.317 回答
0

首先我们需要写入我们的内存流,然后在内存流方法“WriteTo”的帮助下,我们可以写入页面的响应,如下面的代码所示。

   MemoryStream filecontent = null;
   filecontent =//CommonUtility.ExportToPdf(inputXMLtoXSLT);(This will be your MemeoryStream Content)
   Response.ContentType = "image/pdf";
   string headerValue = string.Format("attachment; filename={0}", formName.ToUpper() + ".pdf");
   Response.AppendHeader("Content-Disposition", headerValue);

   filecontent.WriteTo(Response.OutputStream);

   Response.End();

FormName 是给定的文件名,此代码将通过调用 PopUp 使生成的 PDF 文件可下载。

于 2014-02-20T17:08:25.317 回答
0

这很简单。困难的部分是获取有关打印状态完成和总页码的有用信息。

var pq = LocalPrintServer.GetDefaultPrintQueue();
var theJob = pq.AddJob();
try{
    using(var js = theJob.JobStream){
        var buffer = File.ReadAllBytes("yourPathToPdf");
        js.Write(buffer,0,buffer.Length);
    }
    var done=false;
    while(!done)
    {
        pq.Refresh();
        theJob.Refresh();
        done = theJob.IsCompleted || theJob.IsDeleted || theJob.IsPrinted;
    }
}
catch(Exception ex){
    //handle this
}
finally{
    theJob?.Dispose();
    pq?.Dispose();
}

当然,这是假设您的打印机具有原生 PDF 支持。否则,您将不得不自己在客户端上完成渲染工作,并且不能将其作为原始流发送。

于 2016-01-06T19:34:52.990 回答