Konvertieren eines Bildes in Base64-String mit JavaScript
- 
          
            Verwenden Sie 
canvas, um das Bild in JavaScript in einen Base64-String zu konvertieren - 
          
            Verwenden Sie 
FileReader, um das Bild mit JavaScript in eine Base64-Zeichenfolge zu konvertieren 
JavaScript hat die Konvention, eine Bild-URL oder ein Bild von einem lokalen PC in eine Base64-Zeichenfolge zu konvertieren. Diese Zeichenfolge kann eine große Anzahl von Symbolen und Buchstaben enthalten.
Wir werden das Erstellen eines canvas-Elements besprechen, das Bild darin laden und toDataURL verwenden, um die String-Darstellung anzuzeigen. Wir werden auch die Option file reader ausprobieren, um die base64-String-Darstellung zu erhalten.
Verwenden Sie canvas, um das Bild in JavaScript in einen Base64-String zu konvertieren
In diesem Fall erstellen wir ein canvas-Element und definieren seine Abmessungen – die dataURL, in der wir die Zeichenkettendarstellung speichern.
Wir fügen zufällige Bilder aus Online-Quellen hinzu und stellen zur Vermeidung von Sicherheitsproblemen sicher, dass object.crossOrigin = 'Anonymous' ist. Schließlich bringt unsere Callback-Funktion die dataURL zur toDataURL-Funktion, um das Fenster darauf hinzuweisen, eine Vorschau der base64-Zeichenfolge für das entsprechende Bild anzuzeigen.
Code-Auszug:
<!DOCTYPE html>
<html lang="en">
  
<head>
  <title>Test</title>
  <style>
    img{
      height: 200px;
    }
  </style>
</head>
<body>
 <img src="https://images.unsplash.com/photo-1606115915090-be18fea23ec7?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=465&q=80" id="myImg">
  <script>
  function toDataURL(src, callback){
    var image = new Image();
    image.crossOrigin = 'Anonymous';
 
    image.onload = function(){
      var canvas = document.createElement('canvas');
      var context = canvas.getContext('2d');
      canvas.height = this.naturalHeight;
      canvas.width = this.naturalWidth;
      context.drawImage(this, 0, 0);
      var dataURL = canvas.toDataURL('image/jpeg');
      callback(dataURL);
    };
    image.src = src;
  }
      toDataURL('https://images.unsplash.com/photo-1606115915090-be18fea23ec7?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=465&q=80', function(dataURL){
        alert(dataURL);      
    })
  </script>
</body>
  
</html>
Ausgabe:

Verwenden Sie FileReader, um das Bild mit JavaScript in eine Base64-Zeichenfolge zu konvertieren
Für eine Konvention zum Lesen von Dateien initialisieren wir dynamisch ein neues Objekt. Das Objekt löst die onload-Methode aus und zeichnet den base64-String. Unser Eingabe-Element nimmt Bilder vom lokalen Computer durch Hochladen auf.
Code-Auszug:
<!DOCTYPE html>
<html lang="en">
<head>
</head>
<body>
    <input type="file" name="" id="fileId" 
        onchange="Uploaded()">
    <br><br>
    <button onclick="display()">
        Display String
    </button>
</body>
</html>
var base64String = '';
function Uploaded() {
  var file = document.querySelector('input[type=file]')['files'][0];
  var reader = new FileReader();
  reader.onload = function() {
    base64String = reader.result.replace('data:', '').replace(/^.+,/, '');
    imageBase64Stringsep = base64String;
  } reader.readAsDataURL(file);
}
function display() {
  console.log('Base64String about to be printed');
  alert(base64String);
}
Ausgabe:

