Base64로 이미지 변환


85
<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
HTML5 파일 API에 대해 무엇을 이해하지 못 하셨나요? 무엇을 시도 했습니까? 무엇이 작동하지 않았습니까?
epascarello 2013-07-17

@epascarello 그들은 실제로 완전히 지원되지 않습니다 caniuse.com/#feat=fileapi 나는 해결 방법이 필요합니다. 특히 안드로이드 버전이 여전히 오래된 iOS 버전뿐만 아니라 (이전 버전) 사용되기 때문에 IE9를 포함하고 싶습니다. P : 여전히 많이 사용됩니다
과장

무엇에 대한 해결 방법? 파일로 무엇을하려고합니까? base64file()-플러그인인가요?
David Hellsing 2013-07-17

난 그냥 자신의 PC에서 파일을 선택 사용자 일단 base64로 파일을 좀하고 싶습니다 @ 데이비드, base64file ()는 단지 예입니다
과장

1
그래 @epascarello 모든 브라우저를 지원하는 방법을 정확하게 내 질문에,였습니다 : D
과장

답변:


210

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 인코딩 이미지 (문자열) 원본 이미지 데이터 크기의 4/3)

여러 이미지 업로드에 대해이 답변을 확인하십시오 .

브라우저 지원 : http://caniuse.com/#search=file%20api
추가 정보 : https://developer.mozilla.org/en-US/docs/Web/API/FileReader


2
네 감사합니다. 실제로 파일 리더가 완전히 지원되지 않는다는 것을 알 수 있습니다. 이전 Android / iOS 장치도 동일한 지원을 어떻게 만들 수 있습니까?
과격한

1
다른 브라우저가 있습니까? xD
RicardoE 2014 년

그것은 이미지를 base64로 변환하기위한 정말 깔끔한 코드였습니다. javascript에서 이것을 이미지로 다시 변환 할 수 있습니까? 나는 전에 base64 인코딩 디코딩을 사용했지만 이미지 변환에 대해 전혀 모른다 ..
The Coder

@TheCoder base64 문자열로 img src에 바로 넣을 수 있으며, 이미지 데이터를 가져 오기 위해 캔버스 컨텍스트를 사용할 수 있습니다.
Qwerty

1
@bombastic JS를 사용하여 두 플랫폼에서 모두 iOS 및 Android 앱을 빌드했습니다. 아이폰 OS는 정상이며 안드로이드에, 나는 갤러리에 대한 권한을 얻기 위해 몇 가지 기본 코드를 필요로했다 ...
오스만 가니 칸 Masum

36

정확히 필요한 것 :) 콜백 버전 또는 Promise 버전을 선택할 수 있습니다. Promise는 Promise polyfill lib를 사용하는 경우에만 IE에서 작동합니다.이 코드를 페이지에 한 번만 입력하면이 함수가 모든 파일에 나타납니다.

loadend 이벤트는 리소스로드에서 진행이 중지되면 시작됩니다 (예 : "오류", "중단"또는 "로드"가 전달 된 후).

콜백 버전

        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

이 경우 Deferred Object 로 작업하고 promise를 반환하는 것이 유용합니다 .

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
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.