生成PDF时wkHtmlToPdf css未应用

时间:2017-01-09 09:45:18

标签: c# css asp.net-mvc-5 wkhtmltopdf

我有一个MVC应用程序,想要使用HTML生成PDF。在这里,我使用wkHTMLtoPdf exe来完成我的工作。

我使用jquery从客户端调用一个action方法。然后它打到下面的方法。

public FileContentResult ExportInvoiceASPDF(string invno)
        {
            try
            {
                Byte[] bytes;                
                var fullUrl = this.Url.Action("pdfCustomerInvoice", "Report", new { invNo = invno }, Request.Url.Scheme);
                bytes = WKHtmlToPdf(fullUrl);

                FileContentResult result = new FileContentResult(bytes, "application/pdf")
                {
                    FileDownloadName = "PriceNotification"
                };
                return File(result.FileContents, "application/pdf");
            }
            catch (Exception ex)
            {

                throw;
            }
        }

在这里,我调用了WKHtmlToPdf函数来获取字节流。 (下面从stackoverflow线程中提取的代码)

public byte[] WKHtmlToPdf(string url_input)
        {
            try
            {
                var fileName = " - ";
                var wkhtmlDir = ConfigurationSettings.AppSettings["wkhtmlDir"];//Directory of wkHtmltopdf exe
                var wkhtml = ConfigurationSettings.AppSettings["wkhtml"];//wkhtmltopdf exe location
                var p = new Process();

                url = url_input;

                p.StartInfo.CreateNoWindow = true;
                p.StartInfo.RedirectStandardOutput = true;
                p.StartInfo.RedirectStandardError = true;
                p.StartInfo.RedirectStandardInput = true;
                p.StartInfo.UseShellExecute = false;
                p.StartInfo.FileName = wkhtml;
                p.StartInfo.WorkingDirectory = wkhtmlDir;

                string switches = "";
                switches += "--print-media-type ";
                switches += "--margin-top 10mm --margin-bottom 10mm --margin-right 10mm --margin-left 10mm ";
                switches += "--page-size Letter ";
                p.StartInfo.Arguments = switches + " " + url + " " + fileName;               
                p.Start();

                //read output
                byte[] buffer = new byte[32768];
                byte[] file;
                using (var ms = new MemoryStream())
                {
                    while (true)
                    {
                        int read = p.StandardOutput.BaseStream.Read(buffer, 0, buffer.Length);

                        if (read <= 0)
                        {
                            break;
                        }
                        ms.Write(buffer, 0, read);
                    }
                    file = ms.ToArray();
                }

                // wait or exit
                p.WaitForExit(60000);

                // read the exit code, close process
                int returnCode = p.ExitCode;
                p.Close();

                return returnCode == 0 ? file : null;
            }
            catch (Exception ex)
            {

                // set your exceptions here
                return null;
            }
        }

这里我执行视图。 (我想以PDF格式导出的页面)

public ActionResult pdfCustomerInvoice(string invNo)
        {
            var inv = _customerInvoiceService.GetCustomerInvoice(invNo);

            InvoiceSummaryReportsVM invRepVM = new InvoiceSummaryReportsVM();

           //My data assigning part going here

            return View(invRepVM);
        }

这是pdfCustomerInvoice html。

@model Pro.Web.Models.ViewModels.InvoiceSummaryReportsVM

@{
    Layout = null;
}

<html>
<head>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">   
</head>
<body>

    <div class="center">
        <h2>Tax Invoice</h2>
    </div>

    <div class="row">
        <br />
        <br />
        <br />
        <br />
        <br />
    </div>

    <div class="row">
        <div class="col-md-6">

        </div>
        <div class="col-md-6">
            <div class="row">
                <div class="col-md-3">
                    @Html.LabelFor(model => model.InvoiceNo, htmlAttributes: new { @class = "control-label" })
                </div>
                <div class="col-md-3">
                    @Html.DisplayFor(model => model.InvoiceNo, new { htmlAttributes = new { @class = "form-control" } })
                </div>
            </div>


            <div class="row">
                <div class="col-md-3">
                    @Html.LabelFor(model => model.InvoiceDate, htmlAttributes: new { @class = "control-label" })
                </div>
                <div class="col-md-3">
                    @Html.DisplayFor(model => model.InvoiceDate, new { htmlAttributes = new { @class = "form-control" } })
                </div>
            </div>

            <div class="row">
                <div class="col-md-3">
                    @Html.LabelFor(model => model.AccountNo, htmlAttributes: new { @class = "control-label" })
                </div>
                <div class="col-md-3">
                    @Html.DisplayFor(model => model.AccountNo, new { htmlAttributes = new { @class = "form-control" } })
                </div>
            </div>

            <div class="row">
                <div class="col-md-3">
                    @Html.LabelFor(model => model.InvoiceStatementPeriod, htmlAttributes: new { @class = "control-label" })
                </div>
                <div class="col-md-3">
                    @Html.DisplayFor(model => model.InvoiceStatementPeriod, new { htmlAttributes = new { @class = "form-control" } })
                </div>
            </div>


        </div>

    </div>

    <div class="row">
        <div class="col-md-6">
            @Html.LabelFor(model => model.OpeningBalance, htmlAttributes: new { @class = "control-label" })
        </div>
        <div class="col-md-6">
            @Html.DisplayFor(model => model.OpeningBalance, new { htmlAttributes = new { @class = "form-control" } })
        </div>
    </div>

    <div class="row">
        <div class="col-md-6">
            @Html.LabelFor(model => model.InvoiceTotal, htmlAttributes: new { @class = "control-label" })
        </div>
        <div class="col-md-6">
            @Html.DisplayFor(model => model.InvoiceTotal, new { htmlAttributes = new { @class = "form-control" } })
        </div>
    </div>

    <div class="row">
        <div class="col-md-6">
            @Html.LabelFor(model => model.TaxAmount, htmlAttributes: new { @class = "control-label" })
        </div>
        <div class="col-md-6">
            @Html.DisplayFor(model => model.TaxAmount, new { htmlAttributes = new { @class = "form-control" } })
        </div>
    </div>

    <div class="row">
        <div class="col-md-6">
            @Html.LabelFor(model => model.TotalAmountPayable, htmlAttributes: new { @class = "control-label" })
        </div>
        <div class="col-md-6">
            @Html.DisplayFor(model => model.TotalAmountPayable, new { htmlAttributes = new { @class = "form-control" } })
        </div>
    </div>


</body>


</html>

问题是当我执行代码时,它生成的PDF没有样式。 (所有数据都与左侧对齐。) 但是当我打电话给&#34; pdfCustomerInvoice&#34;方法直接,html适当的样式。

在这里,我有造型问题。请给我一个解决这个问题的方向。

1 个答案:

答案 0 :(得分:1)

似乎引导程序不会加载。 尝试从文件系统链接bootstrap css。

详细信息:https://stackoverflow.com/a/20357784/6589639