ブラウザにクリックで画像ファイルをダウンロードさせる


100

Excelシートをクリックしているときと同じように、ブラウザで画像ファイルをダウンロードする必要があります。

クライアント側のプログラミングのみを使用してこれを行う方法はありますか?

<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <title></title>
        <script type="text/javascript" src="Scripts/jquery-1.10.2.js">
        $(document).ready(function () {
            $("*").click(function () {
                $("p").hide();
            });
        });
        </script>
    </head>

    <script type="text/javascript">
        document.onclick = function (e) {
            e = e || window.event;
            var element = e.target || e.srcElement;
            if (element.innerHTML == "Image") {
                //someFunction(element.href);
                var name = element.nameProp;
                var address = element.href;
                saveImageAs1(element.nameProp, element.href);
                return false; // Prevent default action and stop event propagation
            }
            else
                return true;
        };

        function saveImageAs1(name, adress) {
            if (confirm('you wanna save this image?')) {
                window.win = open(adress);
                //response.redirect("~/testpage.html");
                setTimeout('win.document.execCommand("SaveAs")', 100);
                setTimeout('win.close()', 500);
            }
        }
    </script>

    <body>
        <form id="form1" runat="server">
            <div>
                <p>
                    <a href="http://localhost:55298/SaveImage/demo/Sample2.xlsx" target="_blank">Excel</a><br />
                    <a href="http://localhost:55298/SaveImage/demo/abc.jpg" id="abc">Image</a>
                </p>
            </div>
        </form>
    </body>
</html>

Excelシートをダウンロードする場合、どのように動作しますか(ブラウザは何をしますか)?


7
download属性。
サイムVIDAS

6
ファイルのダウンロードを確実にする最良の方法は、サーバー側でコンテンツの配置を設定することです。ほとんどのクライアント側のソリューションはそれほど信頼できません。
adeneo 2013


:すでにあなたのために答えている同様の問題がある stackoverflow.com/a/6799284/1948211
dschu

Karl-Andre Gagnon:適切に実行してください。[HTML 5にタグを付けていなかったため、使用したくないため]サーバーに触れない
Amit

回答:


172

HTML5を使用すると、リンクに「download」属性を追加できます。

<a href="https://stackoverflow.com/path/to/image.png" download>

準拠しているブラウザは、同じファイル名(この例ではimage.png)でイメージをダウンロードするように要求します。

この属性の値を指定すると、それが新しいファイル名になります。

<a href="https://stackoverflow.com/path/to/image.png" download="AwesomeImage.png">

UPDATE:春2018のように、これはもはや可能であるクロスオリジンのためhref。したがって<a href="https://i.imgur.com/IskAzqA.jpg" download>、imgur.com以外のドメインで作成したい場合、意図したとおりに機能しません。Chromeのサポート終了と削除のお知らせ


Richard Parnaby-King:HTML 5属性を使用してそれを行うことができますが、HTML5またはサーバー側のツールを使用せずに行う必要があります(可能な場合)。ヘルパーに感謝:)
Amit

2
まだすべてのブラウザーで完全にサポートされているわけではありませんが、IEやSafariを気にしないのであれば、これは良い解決策です。caniuse.com/#feat=download
stacigh

HTML5ソリューションをありがとう。保存する前にファイル名を入力できる「名前を付けて保存」を許可するにはどうすればよいですか?
テレマン

このファイルをダウンロードする場所を制御できませんか?ダウンロードフォルダに直接ダウンロードするだけです。htmlファイルのローカルパスを使用したい。
Arjun Chiddarwar 16

1
@ArjunChiddarwarいいえ、それはセキュリティの脆弱性を開きます(悪意のあるファイルをWindowsフォルダーに直接保存している人を想像してください)。ダウンロードパスはブラウザの設定に基づいています。たとえば、デフォルトではChromeはダウンロードフォルダにダウンロードされます。
Richard Parnaby-King 2016

96

ドキュメントへのリンクを追加することで、ChromeとFirefoxでもこれを機能させることができました。

var link = document.createElement('a');
link.href = 'images.jpg';
link.download = 'Download.jpg';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);

2
これは実際、Javascriptがすべての場所にあるWebアプリにとって非常に優れたソリューションです。ただし、Google Chrome(私のテストセットアップ)でのみ機能します。
Pavel

互換性をテストする方法についてのアイデアはありますか?この手法を使用したいが、他のブラウザーもサポートする必要があるため、サポートされていない場合は別の方法(新しいウィンドウでPDFを開く、またはダウンロードするリンクなど)を提供する必要があります。誰かがそれで運がありましたか?
alexrussell 2014年

13
素晴らしい解決策、ありがとう!省略した場合document.body.appendChild(link)、Firefoxでは機能しないことに注意してください。作成した要素をdocument.body.removeChild(link);後から削除するのも良い方法ですlink.click()
akn

8
最良のソリューション。DOMでのゴミを避けるためにsetTimeout( function () { link.parentNode.removeChild( link ); },10 );
Mephiztopheles

1
質問はJAVASCRIPTでそれを行う方法を尋ねたので、感謝が選択されたはずです。
codehelp4 2018

33

リロイ&リチャードパーナビーキング:

更新:2018年春以降、クロスオリジンのhrefではこれができなくなりました。したがって、imgur.com以外のドメインで作成したい場合は、意図したとおりに機能しません。Chromeのサポート終了と削除のお知らせ

function forceDownload(url, fileName){
    var xhr = new XMLHttpRequest();
    xhr.open("GET", url, true);
    xhr.responseType = "blob";
    xhr.onload = function(){
        var urlCreator = window.URL || window.webkitURL;
        var imageUrl = urlCreator.createObjectURL(this.response);
        var tag = document.createElement('a');
        tag.href = imageUrl;
        tag.download = fileName;
        document.body.appendChild(tag);
        tag.click();
        document.body.removeChild(tag);
    }
    xhr.send();
}

2
画像はダウンロードされますが、「画像が壊れています」と表示されて開かない
picacode

18

2018年春更新

<a href="/path/to/image.jpg" download="FileName.jpg">

これはまだサポートされていますが、2018年2月の時点で、Chromeはクロスオリジンダウンロードに対してこの機能を無効にしたため、ファイルが同じドメイン名にある場合にのみ機能します。

クロスドメインのダウンロードを無効にするChromeの新しいアップデート後に、クロスドメインのイメージをダウンロードするための回避策を見つけました。これを関数に変更して、ニーズに合わせることができます。必要に応じて、さらに調査を行って画像のMIMEタイプ(jpeg、png、gifなど)を取得できる場合があります。これと同様のことをビデオでも行う方法があるかもしれません。これが誰かを助けることを願っています!

リロイ&リチャードパーナビーキング:

更新:2018年春以降、クロスオリジンのhrefではこれができなくなりました。したがって、imgur.com以外のドメインで作成したい場合は、意図したとおりに機能しません。Chromeのサポート終了と削除のお知らせ

var image = new Image();
image.crossOrigin = "anonymous";
image.src = "https://is3-ssl.mzstatic.com/image/thumb/Music62/v4/4b/f6/a2/4bf6a267-5a59-be4f-6947-d803849c6a7d/source/200x200bb.jpg";
// get file name - you might need to modify this if your image url doesn't contain a file extension otherwise you can set the file name manually
var fileName = image.src.split(/(\\|\/)/g).pop();
image.onload = function () {
    var canvas = document.createElement('canvas');
    canvas.width = this.naturalWidth; // or 'width' if you want a special/scaled size
    canvas.height = this.naturalHeight; // or 'height' if you want a special/scaled size
    canvas.getContext('2d').drawImage(this, 0, 0);
    var blob;
    // ... get as Data URI
    if (image.src.indexOf(".jpg") > -1) {
    blob = canvas.toDataURL("image/jpeg");
    } else if (image.src.indexOf(".png") > -1) {
    blob = canvas.toDataURL("image/png");
    } else if (image.src.indexOf(".gif") > -1) {
    blob = canvas.toDataURL("image/gif");
    } else {
    blob = canvas.toDataURL("image/png");
    }
    $("body").html("<b>Click image to download.</b><br><a download='" + fileName + "' href='" + blob + "'><img src='" + blob + "'/></a>");
};
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>


このコードは、画像をブラウザのメモリ内のピクセルのバッファにデコードし、jpeg / png / gifとして再エンコードしてから、データをローカルに格納するdata-uriにカプセル化するように見えます。もしそうなら、それは画像ファイルからのすべてのメタデータが失われていることを意味します。また、JPEGを再エンコードすると品質が低下し、品質/バイト数の比率が低下します。それでも、知っておくと便利です。共有いただきありがとうございます。
ステフェイン・グーリッホン

14

Promiseとasync / awaitを使用したより現代的なアプローチ:

toDataURL(url) {
    return fetch(url).then((response) => {
            return response.blob();
        }).then(blob => {
            return URL.createObjectURL(blob);
        });
}

その後

async download() {
        const a = document.createElement("a");
        a.href = await toDataURL("https://cdn1.iconfinder.com/data/icons/ninja-things-1/1772/ninja-simple-512.png");
        a.download = "myImage.png";
        document.body.appendChild(a);
        a.click();
        document.body.removeChild(a);
}

ここでドキュメントを検索:https : //developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch


13
var pom = document.createElement('a');
pom.setAttribute('href', 'data:application/octet-stream,' + encodeURIComponent(text));
pom.setAttribute('download', filename);
pom.style.display = 'none';
document.body.appendChild(pom);
pom.click();
document.body.removeChild(pom);     

5
サファリブラウザーはダウンロード属性をサポートしていません
Pranav Labhe

11

これは問題に対する一般的な解決策です。しかし、ファイル拡張子がエンコーディングと一致する必要がある非常に重要な部分が1つあります。そしてもちろん、downlowadImage関数のコンテンツパラメーターは、画像のbase64エンコードされた文字列である必要があります。

const clearUrl = url => url.replace(/^data:image\/\w+;base64,/, '');

const downloadImage = (name, content, type) => {
  var link = document.createElement('a');
  link.style = 'position: fixed; left -10000px;';
  link.href = `data:application/octet-stream;base64,${encodeURIComponent(content)}`;
  link.download = /\.\w+/.test(name) ? name : `${name}.${type}`;

  document.body.appendChild(link);
  link.click();
  document.body.removeChild(link);
}

['png', 'jpg', 'gif'].forEach(type => {
  var download = document.querySelector(`#${type}`);
  download.addEventListener('click', function() {
    var img = document.querySelector('#img');

    downloadImage('myImage', clearUrl(img.src), type);
  });
});
a gif image: <image id="img" src="" />


<button id="png">Download PNG</button>
<button id="jpg">Download JPG</button>
<button id="gif">Download GIF</button>


3
回答者に関連するように、回答に簡単な説明を追加してください
AGE

1
link.href = 'data:application / octet-stream、' + encodeURIComponent(address)これによりファイルが破損し、開くことができなくなります。カヌーはその理由を示唆しています
OM The Eternity

ええ、この答えは最高のものに値する!私にとって欠けているのは、「cleanUrl」でした。これは、不正な形式のデータを生成し、ファイルを破壊していました。
ユリウスピンザル

2

これを試して:

<a class="button" href="http://www.glamquotes.com/wp-content/uploads/2011/11/smile.jpg" download="smile.jpg">Download image</a>

2

2020年に、Blobを使用して画像のローカルコピーを作成します。このブラウザーはファイルとしてダウンロードします。このサイトでテストできます

ここに画像の説明を入力してください

(function(global) {
  const next = () => document.querySelector('.search-pagination__button-text').click();
  const uuid = () => Math.random().toString(36).substring(7);
  const toBlob = (src) => new Promise((res) => {
    const img = document.createElement('img');
    const c = document.createElement("canvas");
    const ctx = c.getContext("2d");
    img.onload = ({target}) => {
      c.width = target.naturalWidth;
      c.height = target.naturalHeight;
      ctx.drawImage(target, 0, 0);
      c.toBlob((b) => res(b), "image/jpeg", 0.75);
    };
    img.crossOrigin = "";
    img.src = src;
  });
  const save = (blob, name = 'image.png') => {
    const a = document.createElement("a");
    a.href = URL.createObjectURL(blob);
    a.target = '_blank';
    a.download = name;
    a.click();
  };
  global.download = () => document.querySelectorAll('.search-content__gallery-results figure > img[src]').forEach(async ({src}) => save(await toBlob(src), `${uuid()}.png`));
  global.next = () => next();
})(window);

このコードは、画像をブラウザーのメモリ内のピクセル(キャンバス)のバッファーにデコードし、jpeg / png / gifとして再エンコードしてから、データuriにカプセル化し、ローカルに保存するように見えます。もしそうなら、それは画像ファイルからのすべてのメタデータが失われていることを意味します。また、JPEGを再エンコードすると品質が低下し、品質/バイト数の比率が低下します。それでも、知っておくと便利です。共有いただきありがとうございます。
ステフェイン・グーリッホン

0
<html>
<head>
<script type="text/javascript">
function prepHref(linkElement) {
    var myDiv = document.getElementById('Div_contain_image');
    var myImage = myDiv.children[0];
    linkElement.href = myImage.src;
}
</script>
</head>
<body>
<div id="Div_contain_image"><img src="YourImage.jpg" alt='MyImage'></div>
<a href="#" onclick="prepHref(this)" download>Click here to download image</a>
</body>
</html>

0

多くのコードなしでアンカータグを使用してこのファイルを直接ダウンロードできます。
スニペットをコピーしてテキストエディターに貼り付けて、試してみてください...!

<html>
<head>
</head>
<body>
   <div>
     <img src="https://upload.wikimedia.org/wikipedia/commons/1/1f/SMirC-thumbsup.svg" width="200" height="200">
      <a href="#" download="https://upload.wikimedia.org/wikipedia/commons/1/1f/SMirC-thumbsup.svg"> Download Image </a>
   </div>
</body>
</html>


2
このコードを使用できる場所など、詳細を追加してください。
Maciej S.

-2

.click()関数とタグの使用についてはどうですか?

(圧縮バージョン)

<a id="downloadtag" href="examplefolder/testfile.txt" hidden download></a>

<button onclick="document.getElementById('downloadtag').click()">Download</button>

これで、jsでトリガーできます。他の例のように、画像やテキストファイルも開かない!

(js関数バージョン)

function download(){
document.getElementById('downloadtag').click();
}
<!-- HTML -->
<button onclick="download()">Download</button>
<a id="downloadtag" href="coolimages/awsome.png" hidden download></a>


-4

見つけた

<a href="link/to/My_Image_File.jpeg" download>Download Image File</a>

私にとってはうまくいきませんでした。理由はわかりません。

?download=trueリンクの最後にパラメータを含めて、ダウンロードを強制できることがわかりました。このテクニックがGoogleドライブで使用されていることに気付いたと思います。

リンクに、?download=truehrefの最後に含めます。

この手法を使用して、同時にファイル名を設定することもできます。

リンクに、?download=true&filename=My_Image_File.jpeghrefの最後に含めます。


2
?download = trueがGoogleドライブに渡され、サーバーに正しいヘッダーを送信して画像をダウンロードするように指示します。それがそのように特別に設定されていない限り、他の環境で機能するものではありません。
muncherelli 2016

-15

それを行うためにjsを書く必要はありません、単に以下を使用してください:

<a href="path_to/image.jpg" alt="something">Download image</a>

そして、ブラウザ自体が自動的に画像をダウンロードします。

何らかの理由で機能しない場合は、download属性を追加します。この属性を使用して、ダウンロード可能なファイルの名前を設定できます。

<a href="path_to/image.jpg" download="myImage">Download image</a>

ブラウザへの設定が異なる場合を除き、画像へのリンクは同じウィンドウでのみ画像を開きます。このdownload属性はすべてのブラウザでサポートされているわけではありません。
Adrianによるデザイン
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.