【问题标题】:Generate PDF using EVOPdf, WebAPI and AngularJS使用 EVOPdf、WebAPI 和 AngularJS 生成 PDF
【发布时间】:2015-11-03 05:42:03
【问题描述】:

我在使用 EVOPdfWebAPI 控制器AngularJS 应用程序呈现 PDF 时遇到问题。

这是我目前的代码:

角度调用:

var url = 'api/form/build/' + id;

$http.get(url, null, { responseType: 'arraybuffer' })
.success(function (data) {
    var file = new Blob([data], { type: 'application/pdf' });

    if (window.navigator && window.navigator.msSaveOrOpenBlob) {
        window.navigator.msSaveOrOpenBlob(file);
    }
    else {
        var objectUrl = URL.createObjectURL(file);
    window.open(objectUrl);
    }
});

APIController 方法:

var url = "http://localhost/index.html#/form/build/" + id;

#region PDF Document Setup
HtmlToPdfConverter htmlToPdfConverter = new HtmlToPdfConverter();

htmlToPdfConverter.LicenseKey = "4W9+bn19bn5ue2B+bn1/YH98YHd3d3c=";
//htmlToPdfConverter.HtmlViewerWidth = 1024; //default
htmlToPdfConverter.PdfDocumentOptions.PdfPageSize = PdfPageSize.A4;
htmlToPdfConverter.PdfDocumentOptions.PdfPageOrientation = PdfPageOrientation.Portrait;
htmlToPdfConverter.ConversionDelay = 3;
htmlToPdfConverter.MediaType = "print";

htmlToPdfConverter.PdfDocumentOptions.LeftMargin = 10;
htmlToPdfConverter.PdfDocumentOptions.RightMargin = 10;
htmlToPdfConverter.PdfDocumentOptions.TopMargin = 10;
htmlToPdfConverter.PdfDocumentOptions.BottomMargin = 10;
htmlToPdfConverter.PdfDocumentOptions.TopSpacing = 10;
htmlToPdfConverter.PdfDocumentOptions.BottomSpacing = 10;
htmlToPdfConverter.PdfDocumentOptions.ColorSpace = ColorSpace.RGB;

// Set HTML content destination in PDF page
htmlToPdfConverter.PdfDocumentOptions.Width = 640;

htmlToPdfConverter.PdfDocumentOptions.FitWidth = true;
htmlToPdfConverter.PdfDocumentOptions.StretchToFit = true; 
#endregion

byte[] outPdfBuffer = htmlToPdfConverter.ConvertUrl(url);

string outPdfFile = @"c:\temp\forms\" + id + ".pdf";
System.IO.File.WriteAllBytes(outPdfFile, outPdfBuffer);


HttpResponseMessage result = null;
result = Request.CreateResponse(HttpStatusCode.OK);
result.Content = new ByteArrayContent(outPdfBuffer.ToArray());
result.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment");
result.Content.Headers.ContentDisposition.FileName = "filename.pdf";
result.Content.Headers.ContentType = new MediaTypeHeaderValue("application/pdf");

return result;

当我检查我使用 WriteAllBytes 写出的 PDF 时,它呈现完美,但是当它通过 Angular 调用返回并在 Adob​​e Reader 中打开时,我得到一个 “无效色彩空间”弹出很多次的错误消息,但未打开文档。当我将色彩空间更改为灰度时,PDF 会打开但它是空白的。

我感觉是 ByteArrayContent 转换导致了问题,因为这是在实际创建 PDF 并将其发送回 Angular 调用之间唯一发生的事情,但我遇到了难题不知道是什么问题。

非常感谢你们能提供的任何帮助,因为我已经快要解决这个问题了,我只需要在电话返回时正确“转换”文档。

提前感谢您的帮助。

问候, 约翰。

【问题讨论】:

  • 我刚刚经历过这件事!不幸的是,目前只能在我的手机上,所以不能真正给你一个像样的答案,但给你一个线索,这与 ajax 无法下载 blob/pdf 有关。尝试使用 filesave.js,我已经设法让它适用于 Mac 上除 safari 之外的所有用户(到目前为止)。
  • 我遇到了完全相同的问题...您找到解决方法了吗?我只是卡住了:(
  • 这里也一样。有人有解决办法吗?

标签: javascript angularjs pdf asp.net-web-api evopdf


【解决方案1】:

//安装puppeteer-core npm包cmd

            npm i puppeteer-core
            # or "yarn add puppeteer-core"
    
           <!-- example.js start-->

       const puppeteer = require('puppeteer');
    
        (async () => {
          const browser = await puppeteer.launch();
          const page = await browser.newPage();
          await page.goto('https://example.com');
          await page.screenshot({ path: 'example.png' });
        
          await browser.close();
        })();
  • 在命令行执行脚本

    节点示例.js

    Puppeteer 将初始页面大小设置为 800×600px,它定义了屏幕截图的大小。页面大小可以通过 Page.setViewport() 自定义。

    示例 - 创建 PDF。

  • 将文件另存为 hn.js

const puppeteer = require('puppeteer');

(async () => {
  const browser = await puppeteer.launch();
  const page = await browser.newPage();
  await page.goto('https://news.ycombinator.com', {
    waitUntil: 'networkidle2',
  });
  await page.pdf({ path: 'hn.pdf', format: 'a4' });

  await browser.close();
})();
  • 在命令行执行脚本

    节点 hn.js 有关创建 pdf 的更多信息,请参阅 Page.pdf()。

    示例 - 在页面上下文中评估脚本

  • 将文件另存为 get-dimensions.js

const puppeteer = require('puppeteer');

(async () => {
  const browser = await puppeteer.launch();
  const page = await browser.newPage();
  await page.goto('https://example.com');

  // Get the "viewport" of the page, as reported by the page.
  const dimensions = await page.evaluate(() => {
    return {
      width: document.documentElement.clientWidth,
      height: document.documentElement.clientHeight,
      deviceScaleFactor: window.devicePixelRatio,
    };
  });

  console.log('Dimensions:', dimensions);

  await browser.close();
})();
  • 在命令行执行脚本

    node get-dimensions.js

    请参阅 Page.evaluate() 以获取有关评估和相关方法(如 evaluateOnNewDocument 和 exposeFunction)的更多信息。

【讨论】:

    【解决方案2】:

    你试过Headless Chrome吗? Here 是一篇关于这个主题的好文章。为此,我使用 https://github.com/puppeteer/puppeteer,这是一个易于集成的解决方案。

    【讨论】:

      【解决方案3】:

      问题似乎在客户端,响应中的字符未正确解析。对于任何为此苦苦挣扎的人,我在这里找到了我的解决方案:SO Question

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2015-06-03
        • 2015-07-27
        • 2015-05-06
        相关资源
        最近更新 更多