javascript - 浏览器/HTML 强制从 src ="data:image/jpeg;base64..."下载图像

标签 javascript image html browser

我在客户端生成图像并用 HTML 显示它,如下所示:

<img src="...."/>

我想提供下载生成的图像的可能性。

我如何才能意识到浏览器正在打开一个文件保存对话框(或者像 chrome 或 firefox 一样将图像下载到下载文件夹就可以),这允许用户保存图像而无需右键单击并保存正如图片上的

我更喜欢没有服务器交互的解决方案。所以我知道如果我先上传图像然后开始下载是可能的。

非常感谢!

最佳答案

只需将 image/jpeg 替换为 application/octet-stream。客户端不会将 URL 识别为可内联资源,并提示下载对话框。

一个简单的 JavaScript 解决方案是:

//var img = reference to image
var url = img.src.replace(/^data:image\/[^;]+/, 'data:application/octet-stream');
window.open(url);
// Or perhaps: location.href = url;
// Or even setting the location of an <iframe> element, 

另一种方法是使用 blob: URI:

var img = document.images[0];
img.onclick = function() {
    // atob to base64_decode the data-URI
    var image_data = atob(img.src.split(',')[1]);
    // Use typed arrays to convert the binary data to a Blob
    var arraybuffer = new ArrayBuffer(image_data.length);
    var view = new Uint8Array(arraybuffer);
    for (var i=0; i<image_data.length; i++) {
        view[i] = image_data.charCodeAt(i) & 0xff;
    }
    try {
        // This is the recommended method:
        var blob = new Blob([arraybuffer], {type: 'application/octet-stream'});
    } catch (e) {
        // The BlobBuilder API has been deprecated in favour of Blob, but older
        // browsers don't know about the Blob constructor
        // IE10 also supports BlobBuilder, but since the `Blob` constructor
        //  also works, there's no need to add `MSBlobBuilder`.
        var bb = new (window.WebKitBlobBuilder || window.MozBlobBuilder);
        bb.append(arraybuffer);
        var blob = bb.getBlob('application/octet-stream'); // <-- Here's the Blob
    }

    // Use the URL object to create a temporary URL
    var url = (window.webkitURL || window.URL).createObjectURL(blob);
    location.href = url; // <-- Download!
};

相关文档

关于javascript - 浏览器/HTML 强制从 src ="data:image/jpeg;base64..."下载图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10473932/

相关文章:

javascript - 在 html 中加载 javascript 的理想位置在哪里?

c# - Javascript 确认或其他类型的确认

javascript - ComboBox 抛出错误 :Unable to get property 'createRange' of undefined or null reference

c++ - 使用 C 读取图像的所有字节并存储在字节数组中

javascript - 设置 Canvas 中图像的大小

javascript - 如何使用 Javascript 创建带有 Sprite Sheet 的动画按钮?

javascript - 使用纯 JavaScript 在页面加载时重新定位 div

javascript - 使用 Google Maps API 在 Google map 上的不同位置使用不同的颜色

android - 关于 Glide 库的详细信息

html - 在 html 中内联显示的错误定位文本