web-dev-qa-db-ja.com

新しいタブでBase64を開く

PDFファイルまたは画像)のBase64エンコードドキュメントがあります。HTML5ページに、このbase64を新しいタブ(または重要ではない新しいページ)で開くボタンを作成します

私はこのコードがトリックを実行できることを発見しました:

<a href="http://chriscoyier.net" 
   onclick="window.open(this.href); return false;" 
   onkeypress="window.open(this.href); return false;">
     This link will open in new window/tab
</a>

それはうまくいきます。しかし、httpリンクを

href="data:application/octet-stream;base64,/9j/4A.."

その後、ファイルはダウンロードされますが、ブラウザには表示されません。

どうすれば作成できますか?

ありがとう

9
user3249592

chromeおよびFirefoxでテストされています。hbase属性にbase64値を追加するだけで機能します(onclick&onkeypressイベントなしで)。

<html>

<body>
  <a href="">test</a>
</body>

</html>
6

MIMEタイプは「application/octet-stream」に設定されており、通常はダウンロードされて表示されません(ブラウザーとシステムの設定によって異なります)。ブラウザで表示可能なコンテンツをロードする場合は、コンテンツに適切なMIMEタイプを使用して、インラインで表示され、ダウンロードされないようにする必要があります。

注意: Chrome 6FireFoxの次期バージョン (FireFoxと表示されますが、 まだ画像をサポートします )、データURIはブラウザーの最上位フレームで開くことはできません(そして IE/Edgeではサポートされていませんでした )。ただし、iframeおよびimg要素で開くことはできます。

以下の回避策は、上記のブラウザの最新バージョンでテストされ、動作しています。これは、画像を表示するためにimgタグで書き換えることもできます。

<button id='btnDownload'>Download</button>
document.getElementById('btnDownload').addEventListener('click', function(){
    var w = window.open('about:blank');

    setTimeout(function(){ //FireFox seems to require a setTimeout for this to work.
        w.document.body.appendChild(w.document.createElement('iframe'))
            .src = 'data:application/octet-stream;base64,SWYgSSBoYWQgYSBuaWNrbGUgZm9yIGV2ZXJ5IHRpbWUgSSBoYWQgYSBuaWNrbGUsIEknZCBoYXZlIGVhdGVuIHR3aWNlIGFzIG1hbnkgcGlja2xlcy4=';
    }, 0);
});

ただし、コンテンツを単にダウンロードすることを意図している場合(質問で述べられている意図に反しますが、「application/octet-stream」コンテンツ全般に適用可能)、これで十分です。

<a href='data:application/octet-stream;base64,SWYgSSBoYWQgYSBuaWNrbGUgZm9yIGV2ZXJ5IHRpbWUgSSBoYWQgYSBuaWNrbGUsIEknZCBoYXZlIGVhdGVuIHR3aWNlIGFzIG1hbnkgcGlja2xlcy4=' download>Download this</a>
12
Aaron J Spetner
    <a href="aHR0cHM6Ly93d3cuc3dpdGNoLXRvcnJlbnRzLmNvbS9kb3dubG9hZC80MTMvU3VwZXIlMjBTbWFzaCUyMEJyb3MlMjBVbHRpbWF0ZS50b3JyZW50" 
     onclick="window.open(this.href); return false;" 
     onkeypress="window.open(this.href); return false;">
       This link will open in new window/tab
    </a>
0
Liam Fisenne

アーロンの答えに基づいて私の質問に答えを追加しています:

document.getElementById('btnDownload').addEventListener('click', function(){
    var w = window.open('about:blank');
    setTimeout(function(){ //FireFox seems to require a setTimeout for this to 
    work.

        w.document.body.appendChild(w.document.createElement('iframe'))
            .src = $this.attr('href');
        w.document.getElementsByTagName("iframe")[0].style.width = '100%';
        w.document.getElementsByTagName("iframe")[0].style.height = '100%';
    }, 0);
});
0
richardwhitney