如何下载base64编码的图像?

Mar*_*rio 9 html javascript base64 image

我有一个来自服务器的base64编码图像,我想通过JavaScript强制下载.有可能吗?

小智 54

使用 Javascript 执行此操作的简单方法...

    var a = document.createElement("a"); //Create <a>
    a.href = "data:image/png;base64," + ImageBase64; //Image Base64 Goes here
    a.download = "Image.png"; //File name Here
    a.click(); //Downloaded file
Run Code Online (Sandbox Code Playgroud)

  • 如果文件太大(例如 4M 字符),则会出现错误 (2认同)

Ehs*_*adi 22

它是如此简单,只需使用下面的功能:

// Parameters:
// contentType: The content type of your file. 
//              its like application/pdf or application/msword or image/jpeg or
//              image/png and so on
// base64Data: Its your actual base64 data
// fileName: Its the file name of the file which will be downloaded. 

function downloadBase64File(contentType, base64Data, fileName) {
     const linkSource = `data:${contentType};base64,${base64Data}`;
     const downloadLink = document.createElement("a");
     downloadLink.href = linkSource;
     downloadLink.download = fileName;
     downloadLink.click();
}
Run Code Online (Sandbox Code Playgroud)

  • 谢谢人!你是一种生活品味。顺便说一句,我们不需要 ```` `data:${contentType};base64,${base64Data}`; ```` 代替 ```` `${base64Data}`;````就够了 (2认同)

Min*_*hev 13

如果您想使用JavaScript(没有任何后端)下载它,请使用:

window.location.href = 'data:application/octet-stream;base64,' + img;
Run Code Online (Sandbox Code Playgroud)

img你的base64编码图像在哪里.

如果要允许用户指定文件名,请使用标记的download属性a:

<a download="FILENAME.EXT" href="data:image/png;base64,asdasd...">Download</a>
Run Code Online (Sandbox Code Playgroud)
  • 注意:下载属性不受广泛支持.

  • windows.location.href不下载图像而是显示所有文本 (3认同)
  • 谢谢,但是第一个选项不会强制下载 (2认同)

Sen*_*ent 9

我从 Chrome 如何获取整页屏幕截图的源代码中找到了这个解决方案。

const base64string = "";
const pageImage = new Image();
pageImage.src = 'data:image/png;base64,' + base64string;
pageImage.onload = function() {
    const canvas = document.createElement('canvas');
    canvas.width = pageImage.naturalWidth;
    canvas.height= pageImage.naturalHeight;

    const ctx = canvas.getContext('2d');
    ctx.imageSmoothingEnabled = false;
    ctx.drawImage(pageImage, 0, 0);
    console.log(canvas, pageImage)
    saveScreenshot(canvas);
}
function saveScreenshot(canvas) {
    let fileName = "image"
    const link = document.createElement('a');
    link.download = fileName + '.png';
    console.log(canvas)
    canvas.toBlob(function(blob) {
        console.log(blob)
        link.href = URL.createObjectURL(blob);
        link.click();
    });
};

Run Code Online (Sandbox Code Playgroud)


Gar*_*nde 9

我不知道回答这个问题是否晚了,但我认为更好的解决方案可能是这样。

  1. 从 base64 字符串创建文件

    const convertBase64ToFile = (base64String, fileName) => {
         let arr = base64String.split(',');
         let mime = arr[0].match(/:(.*?);/)[1];
         let bstr = atob(arr[1]);
         let n = bstr.length;
         let uint8Array = new Uint8Array(n);
         while (n--) {
            uint8Array[n] = bstr.charCodeAt(n);
         }
         let file = new File([uint8Array], fileName, { type: mime });
         return file;
    }
    
    Run Code Online (Sandbox Code Playgroud)
  2. 从 npm安装文件保护程序

    npm install file-saver
    
    Run Code Online (Sandbox Code Playgroud)
  3. 导入文件保护程序

    npm install file-saver
    
    Run Code Online (Sandbox Code Playgroud)
  4. 使用文件保存器下载文件

    const { saveAs } = require('file-saver');
    /// OR 
    import { saveAs } from 'file-saver';
    
    Run Code Online (Sandbox Code Playgroud)

如果此答案对您有用,请对其进行投票并将其标记为正确,以帮助其他人轻松找到它


小智 8

在我的 Angular 应用程序中,我从服务器获取 Base 64 文件。

在 HTML 中:-

<button type="button" (click)="downloadFile(fileName,base64data,fileType)"></button>
Run Code Online (Sandbox Code Playgroud)

在 Ts 中:-

  downloadFile(fileName:string,data: any,fileFormat:string): void {
    const linkSource = 'data:'+fileFormat+';base64'+data;
    const downloadLink = document.createElement("a");
    downloadLink.href = linkSource;
    downloadLink.download = fileName;
    downloadLink.click();
}
Run Code Online (Sandbox Code Playgroud)


Ami*_*ole 6

你可以试试这个:

    <!doctype html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>Download Text File DataURL Demo</title>
        <style>
            body{ font: menu; }
        </style>
        <script src='//js.zapjs.com/js/download.js'></script>
    </head>
    <body>
        <h1>Download Text File DataURL Demo</h1>
        <main></main>
        <script>
            download("data:application/octet-stream;base64,YOUR BASE64URL", "dlDataUrlText.jpeg", "application/octet-stream;base64");
        </script>
    </body>

</html>
Run Code Online (Sandbox Code Playgroud)

下载标签使用包含的脚本下载图像。

作为参考,你可以试试这个 URL:http : //danml.com/download.html

  • 当前 js.zapjs.com 上的攻击者可能会尝试在您的计算机上安装危险程序来窃取或删除您的信息。 (2认同)