获取当前页面MVC 5的pdf

Get pdf of current page MVC 5

本文关键字:pdf MVC 当前页 获取      更新时间:2023-09-26

我正试图在视图中获取一个div的pdf。

我正在执行以下操作:我得到元素,对其html进行uri编码,然后通过ajax将其传递给一个方法:

AJAX:

function getPDF(html) {
    $.ajax({
        type: "POST",
        url: "@Url.Action("printPage")",
        data: { html: encodeURIComponent(html) }
    }).done(function (result) {
        window.open("data:application/pdf; " + result);
        $("#printArea").html(result);
    }).fail(function (data) {
        alert("Failed");
    });
}

方法:

[HttpPost]
public void printPage(string html)
{
    String decoded = System.Uri.UnescapeDataString(html);
    var cd = new System.Net.Mime.ContentDisposition
    {
        FileName = "something.pdf",
        Inline = false
    };
    Response.AppendHeader("Content-Disposition", cd.ToString());
    var mem = Bcs.Common.Utilities.HTMLtoPDF.getPDF(decoded);
    //var base64EncodedPDF = System.Convert.ToBase64String(pdfByteArray);
    Response.BinaryWrite(mem.ToArray());
    //return File(mem, System.Net.Mime.MediaTypeNames.Application.Octet);
}

最后,我得到了一个弹出窗口来打开pdf,但它不会打开,根据adobe acrobat的说法,它已经损坏了。

我尝试将html作为permeter发送到该方法,但permeter太长

HTTP Error 404.15 - Not Found The request filtering module is configured to deny a request where the query string is too long.

做这件事的好方法是什么。

public JsonResult printPage(String html)
        {
            String decoded = System.Uri.UnescapeDataString(html);
            var cd = new System.Net.Mime.ContentDisposition
            {
                FileName = "something.pdf",
                Inline = false
            };
            var mem = Bcs.Common.Utilities.HTMLtoPDF.getPDF(decoded);
            mem.Flush();
            mem.Position = 0;
            String b64Converted = Convert.ToBase64String(mem.ToArray());
            return Json(b64Converted, JsonRequestBehavior.AllowGet );

系统。网哑剧表演媒体类型名称。应用Octet);}

然后在视图中:

 $.ajax({
            type: "POST",
            url: "@Url.Action("printPage")",
            data: { html: encodeURIComponent(html) },
        }).done(function (result) {
            $("#printArea").append('<a href="data:application/pdf;base64,' + result + '">PDF</a>');
        }).fail(function (data) {
            alert("Failed");
        });

显然很容易只需对pdf进行base64处理,并在json响应时发送。