แปลงรูปภาพเป็น Base64


84
<input type="file" id="asd"/>

ฉันต้องการรับภาพในbase64เมื่อผู้ใช้เลือกแล้ว (ก่อนส่งแบบฟอร์ม)

สิ่งที่ต้องการ :

$(input).on('change',function(){
  var data = $(this).val().base64file(); // it is not a plugin is just an example
  alert(data);
});

ฉันอ่านเกี่ยวกับ File API และเนื้อหาอื่น ๆ ฉันต้องการโซลูชันที่เรียบง่ายและข้ามเบราว์เซอร์ (ไม่รวม IE6 / IE7 อย่างชัดเจน)

ความช่วยเหลือใด ๆ ที่ชื่นชมขอบคุณ


1
และคุณไม่เข้าใจอะไรเกี่ยวกับ API ของไฟล์ HTML5 คุณลองทำอะไร ไม่ได้ผลอะไร
epascarello

@epascarello พวกเขาไม่ได้รับการสนับสนุนอย่างเต็มที่จริงๆแล้วcaniuse.com/#feat=fileapiฉันต้องการวิธีแก้ไขโดยเฉพาะอย่างยิ่งสาเหตุที่ยังคงใช้เวอร์ชัน Android (เวอร์ชันเก่า) เช่นเดียวกับ iOS เวอร์ชันเก่าและฉันต้องการที่จะเกี่ยวข้องกับ IE9 ซึ่ง ยังคงใช้กันมาก: P
ระเบิด

วิธีแก้ปัญหาสำหรับอะไร? คุณกำลังพยายามทำอะไรกับไฟล์นี้ base64file()- นั่นคือปลั๊กอินหรือไม่?
David Hellsing

@David ฉันแค่อยากได้ไฟล์ base64 เมื่อผู้ใช้เลือกไฟล์จากพีซีของเขา base64file () เป็นเพียงตัวอย่างเท่านั้น
ระเบิด

1
@epascarello ใช่และนั่นคือคำถามของฉันวิธีการรองรับเบราว์เซอร์ทั้งหมด: D
ระเบิด

คำตอบ:


213

function readFile() {
  
  if (this.files && this.files[0]) {
    
    var FR= new FileReader();
    
    FR.addEventListener("load", function(e) {
      document.getElementById("img").src       = e.target.result;
      document.getElementById("b64").innerHTML = e.target.result;
    }); 
    
    FR.readAsDataURL( this.files[0] );
  }
  
}

document.getElementById("inp").addEventListener("change", readFile);
<input id="inp" type='file'>
<p id="b64"></p>
<img id="img" height="150">

( PS:ภาพที่เข้ารหัส base64 (String) 4/3 ขนาดของข้อมูลภาพต้นฉบับ)

ตรวจสอบคำตอบนี้สำหรับภาพหลายภาพที่อัปโหลด

การสนับสนุนเบราว์เซอร์: http://caniuse.com/#search=file%20api
ข้อมูลเพิ่มเติมที่นี่: https://developer.mozilla.org/en-US/docs/Web/API/FileReader


2
ใช่ขอบคุณจริงๆฉันเห็นว่าโปรแกรมอ่านไฟล์ไม่ได้รับการสนับสนุนอย่างสมบูรณ์ฉันจะรองรับอุปกรณ์ Android / iOS รุ่นเก่าได้อย่างไร
ระเบิด

1
มีเบราว์เซอร์อื่น ๆ อีกไหม xD
RicardoE

นั่นเป็นรหัสที่เรียบร้อยจริงๆสำหรับการแปลง image เป็น base64 .. ฉันสามารถแปลงกลับเป็นรูปภาพใน javascript ได้หรือไม่? ฉันเคยใช้การถอดรหัสการเข้ารหัส base64 มาก่อน แต่ไม่มีความคิดเกี่ยวกับการแปลงรูปภาพเลย ..
The Coder

@TheCoder คุณสามารถใส่ลงใน img src เป็นสตริง base64 เพื่อดึงข้อมูลภาพออกมาให้ใช้บริบทผ้าใบ
Qwerty

1
@bombastic ฉันใช้ JS เพื่อสร้างทั้งแอป iOS และ Android บนทั้งสองแพลตฟอร์มพวกเขาทำงานได้ดี iOS เป็นเรื่องปกติและใน Android ฉันต้องใช้โค้ดเนทีฟเพื่อขออนุญาตในแกลเลอรี ...
Osman Gani Khan Masum

35

สิ่งที่คุณต้องการ :) คุณสามารถเลือกเวอร์ชันโทรกลับหรือเวอร์ชันสัญญา โปรดทราบว่าคำสัญญาจะใช้งานได้ใน IE กับ Promise polyfill lib เท่านั้นคุณสามารถใส่รหัสนี้ได้หนึ่งครั้งในหน้าและฟังก์ชันนี้จะปรากฏในไฟล์ทั้งหมดของคุณ

เหตุการณ์ loadend จะเริ่มทำงานเมื่อความคืบหน้าหยุดโหลดทรัพยากร (เช่นหลังจาก "error", "abort" หรือ "load" ถูกส่งไปแล้ว)

เวอร์ชันโทรกลับ

        File.prototype.convertToBase64 = function(callback){
                var reader = new FileReader();
                reader.onloadend = function (e) {
                    callback(e.target.result, e.target.error);
                };   
                reader.readAsDataURL(this);
        };

        $("#asd").on('change',function(){
          var selectedFile = this.files[0];
          selectedFile.convertToBase64(function(base64){
               alert(base64);
          }) 
        });

รุ่นสัญญา

    File.prototype.convertToBase64 = function(){
         return new Promise(function(resolve, reject) {
                var reader = new FileReader();
                reader.onloadend = function (e) {
                    resolve({
                      fileName: this.name,
                      result: e.target.result, 
                      error: e.target.error
                    });
                };   
                reader.readAsDataURL(this);
        }.bind(this)); 
    };

    FileList.prototype.convertAllToBase64 = function(regexp){
      // empty regexp if not set
      regexp = regexp || /.*/;
      //making array from FileList
      var filesArray = Array.prototype.slice.call(this);
      var base64PromisesArray = filesArray.
           filter(function(file){
             return (regexp).test(file.name)
           }).map(function(file){
             return file.convertToBase64();
           });
      return Promise.all(base64PromisesArray);
    };

    $("#asd").on('change',function(){
      //for one file
      var selectedFile = this.files[0];
      selectedFile.convertToBase64().
          then(function(obj){
            alert(obj.result);
          });
      });
      //for all files that have file extention png, jpeg, jpg, gif
      this.files.convertAllToBase64(/\.(png|jpeg|jpg|gif)$/i).then(function(objArray){
            objArray.forEach(function(obj, i){
                  console.log("result[" + obj.fileName + "][" + i + "] = " + obj.result);
            });
      });
    })

html

<input type="file" id="asd" multiple/>

8
<input type="file" onchange="getBaseUrl()">
function getBaseUrl ()  {
    var file = document.querySelector('input[type=file]')['files'][0];
    var reader = new FileReader();
    var baseString;
    reader.onloadend = function () {
        baseString = reader.result;
        console.log(baseString); 
    };
    reader.readAsDataURL(file);
}

1
'file' ถูกประกาศ แต่ค่าของมันจะไม่ถูกอ่านภายในฟังก์ชัน getBaseUrl ()
Biranchi

@Biranchi fileใช้ในบรรทัดสุดท้ายreader.readAsDataURL(file);
Achim

7

การทำงานกับออบเจ็กต์รอการตัดบัญชีมีประโยชน์ในกรณีนี้และส่งคืนสัญญา:

function readImage(inputElement) {
    var deferred = $.Deferred();

    var files = inputElement.get(0).files;
    if (files && files[0]) {
        var fr= new FileReader();
        fr.onload = function(e) {
            deferred.resolve(e.target.result);
        };
        fr.readAsDataURL( files[0] );
    } else {
        deferred.resolve(undefined);
    }

    return deferred.promise();
}

และฟังก์ชันข้างต้นสามารถใช้ในลักษณะนี้:

var inputElement = $("input[name=file]");
readImage(inputElement).done(function(base64Data){
    alert(base64Data);
});

หรือในกรณีของคุณ:

$(input).on('change',function(){
  readImage($(this)).done(function(base64Data){ alert(base64Data); });
});

ฉันต้องการสิ่งนี้จริงๆฉันหมายถึงการรอการตัดบัญชีเนื่องจากฉันส่งคืน base64 เป็นวิธีการโทร ฉันต้องการทราบว่าโซลูชันของคุณจะใช้ได้กับทุกเบราว์เซอร์หรือไม่?
Thameem

0

// https://developer.mozilla.org/en-US/docs/Web/API/FileReader/readAsDataURL

/* Simple */
function previewImage( image, preview, string )
{

    var preview     = document.querySelector( preview );
    var fileImage   = image.files[0];

    var reader      = new FileReader();

    reader.addEventListener( "load", function() {

        preview.style.height    = "100";
        preview.title           = fileImage.name;

        // convert image file to base64 string
        preview.src             = reader.result;

        /* --- */

        document.querySelector( string ).value = reader.result;                    

    }, false );

    if ( fileImage )
    {
        reader.readAsDataURL( fileImage );
    }

}

document.querySelector( "#imageID" ).addEventListener( "change", function() {

    previewImage( this, "#imagePreviewID", "#imageStringID" );

} )
/* Simple || */
<form>

    File Upload: <input type="file" id="imageID" /><br />
    Preview: <img src="#" id="imagePreviewID" /><br />    
    String base64: <textarea id="imageStringID" rows="10" cols="50"></textarea>

</form>

รหัส

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.