如何使用 javascript 在浏览器中显示 PDF 字节数组?

Posted

技术标签:

【中文标题】如何使用 javascript 在浏览器中显示 PDF 字节数组?【英文标题】:How to display a PDF bytearray in browser using javascript? 【发布时间】:2021-11-21 17:30:36 【问题描述】:

我一直在尝试下面的客户端代码来呈现从服务器端返回的 PDF 字节数组。它在浏览器中显示正确数量的缩略图/页面,但内容未显示。缩略图和页面都是全黑的。 我在这里有什么遗漏吗?另外,我读到 createObjectURL 已被弃用。有没有更好的方法来实现这一点?

谢谢!

服务器端代码:

byte[] bytes = service.GetDocument(ID);

result.StatusCode = HttpStatusCode.OK;
result.Content = new ByteArrayContent(bytes, 0, bytes.Length);
result.Content.Headers.ContentType = new MediaTypeHeaderValue("application/pdf");
result.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("inline");

客户端代码:

@model DocumentWeb.ViewModels.Document

<html>
    <body>

        <object data="" type="application/pdf"  >
        </object>

        <script>

            $(document).ready(function (e) 

                $("object").attr("width", screen.availWidth);

                $("object").attr("height", screen.availHeight);

                var url = "@Url.Content("~/pdf/document")";
            
                    var data = 
                        ID: "@Model.DocID",
                    ;

                    var result = $.post(
                        url: url,
                        type: 'POST',
                        data: data
                    );

                    result.done(function (bytearray) 

                        var blob = new Blob([bytearray],  type: 'application/pdf' );

                        var link= window.URL.createObjectURL(blob);

                        $("object").attr("data", link);
                    
                    );

                    result.fail(function (xhr) 
                        console.log(xhr.responseText);
                    );
                
            );

        </script>

    </body>
</html>

【问题讨论】:

你总是可以base64编码你的字节数组。 HTML &lt;object&gt; 标签支持 base64 编码图像。 &lt;object src="data:application/pdf;base64, ABC123... /&gt; 之类的东西,其中 ABC123... 是您的 base64 编码 PDF 二进制文件。 谢谢。现在可以了。 由于我的建议似乎对您有用,因此我已将其作为此问题的答案,以便将来可以帮助其他有类似问题的人。请考虑投票并接受答案。 【参考方案1】:

您始终可以对字节数组进行 base64 编码。 HTML &lt;object&gt; 标签支持 base64 编码图像。 &lt;object src="data:application/pdf;base64, ABC123... /&gt; 之类的东西,其中 ABC123... 是您的 base64 编码 PDF 二进制文件。

【讨论】:

以上是关于如何使用 javascript 在浏览器中显示 PDF 字节数组?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Javascript 启用浏览器 cookie? [复制]

如何使用javascript获取浏览器显示高度和宽度[重复]

如何使用 JavaScript v12 SDK for Browsers 检索和显示(在浏览器中)存储在 Azure 存储帐户中的多个 pdf 的 URL

如何在 HTML 中显示 JavaScript 数组

JavaScript如何在div中动态生成<p>

如何使用 javascript 打开文件/浏览对话框?