1

IFrameのsrc属性をdata:application / pdf; base64に設定しても、うまくいきません。理由は何ですか?

これが.aspxマークアップです

<%@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" %>

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Untitled Page</title>
    <script type="text/javascript">
        function loadIFrameFromHiddenField()
        {         
            //get the node containing the base64 pdf data from the xml in the hidden field
            var xmlDoc = new ActiveXObject("Microsoft.XMLDOM");
            xmlDoc.loadXML(document.getElementById("pdfData").value);                    
            xmlDoc.setProperty('SelectionLanguage', 'XPath');
            var pdfDataNode = xmlDoc.selectSingleNode("//PDF");

            //if we've got the node
            if (pdfDataNode != null) 
            {
                //get the data and append it to the src contents 
                var pdfIFrameSrc = "data:application/pdf;base64," + pdfDataNode.text;
                //set the src attribute
                document.getElementById("pdfIFrame").setAttribute("src", pdfIFrameSrc);
            }            
        }
    </script>
</head>
<body>
    <form id="form1" runat="server" style="width:100%;height:100%;">
        <asp:HiddenField ID="pdfData" runat="server" /> 
        <div style="width:100%;height:80%;"> 
            <iframe id="pdfIFrame" runat="server" scrolling="auto" frameborder="0" marginheight="0" marginwidth="0" style="height:99.5%;width:99.5%" />            
        </div>
    </form>
</body>
</html>

背後にあるコードは次のとおりです。

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.IO;
using System.Text;
using System.Xml;
public partial class _Default : System.Web.UI.Page 
{
    protected void Page_Load(object sender, EventArgs e)
    {

        //get the bytes from our PDF
        Byte[] pdfBytes = File.ReadAllBytes("c:\\temp\\Test.pdf");

        //build xml containiing our base64 encoded pdf data and put it in hidden field
        pdfData.Value = buildDocumentXML(pdfBytes, "TestDoc");

        //call js function to add the src to the iframe
        String scriptText = "<script type='text/javascript'>loadIFrameFromHiddenField()</script>";
        ClientScript.RegisterStartupScript(this.GetType(), "loadIFrameFromHiddenField", scriptText);
    }

    private string buildDocumentXML(Byte[] pdfBytes, string documentName) 
    {

        StringBuilder documentsString = new StringBuilder();
        XmlWriterSettings documentsXmlSettings = new XmlWriterSettings();

        documentsXmlSettings.Indent = false;            
        documentsXmlSettings.OmitXmlDeclaration = true;
        documentsXmlSettings.ConformanceLevel = ConformanceLevel.Fragment;
        documentsXmlSettings.NewLineHandling = NewLineHandling.None;

        using (XmlWriter documentsXmlWriter = XmlWriter.Create(documentsString, documentsXmlSettings))
        {

            documentsXmlWriter.WriteStartElement("DOCUMENTS");

            documentsXmlWriter.WriteStartElement("FILENAME");
            documentsXmlWriter.WriteString(documentName);
            documentsXmlWriter.WriteEndElement();

            documentsXmlWriter.WriteStartElement("PDF");


            documentsXmlWriter.WriteBase64(pdfBytes, 0, pdfBytes.Length);


            documentsXmlWriter.WriteEndElement();



            documentsXmlWriter.WriteEndElement();
        }



        return documentsString.ToString();

    }

}

この例とは異なり、実際のアプリでは、PDFデータはサーバーサイドで生成されます。私がpdfデータクライアントサイドをロードしようとしている理由は、とにかく何か他のことをするためにpdfバイトデータクライアントサイドを持たなければならず、このデータのインスタンスが生成されてチャックされるのを減らしようとしているからです。

上記のコードとマークアップをVS2005の単純な1ページのWebサイトに貼り付け、古いpdfをc:\ temp \に貼り付け、TestDoc.pdfと呼ぶだけで、コンパイルして実行できます。

基本的に、私が得ている動作はiframeではまったくありません。

私はIE7を使用しているので、それが問題になる可能性があります。data:application / pdf; base64 [base64 data]構文の使用に関する貴重な情報がほとんどないため、わかりません。

4

3 に答える 3

1

ウィキペディアを参照するのは面倒かもしれませんが、ウィキペディアによると、data:filetype;base64 構文を使用できるファイルの種類にはいくつかの制限があるかもしれません。つまり、今のところ写真のみです。この記事によると、IE9 の仕様により、より幅広い用途が可能になりますが、それが正確に何を意味するのかはわかりません。当面は、base 64 文字列データだけでなく、.pdf ファイルを使用する必要があります。

于 2012-02-17T23:29:39.460 に答える
0

この方法は私のために働いた:

var oldsrc = $('.content-control-iframe').attr('src');
var newsrc = $('.content-control-iframe').attr('src').slice(8);
$('.content-control-iframe[src="'+oldsrc+'"]').attr('src', newsrc);
于 2016-09-16T14:11:56.947 に答える
-1

私の知る限り、IE は data: URL スキームをまったく処理しないため、PDF ビューアーに何を渡せばよいかわかりません。WPを参照してください。

乾杯、

于 2009-06-24T15:08:36.037 に答える