Как преобразовать dataURL в файл объекта в JavaScript? - PullRequest
36 голосов
/ 27 июля 2011

Мне нужно преобразовать dataURL в объект File в Javascript, чтобы отправить его через AJAX.Является ли это возможным?Если да, скажите, пожалуйста, как.

Ответы [ 3 ]

46 голосов
/ 31 августа 2011

Если вам нужно отправить его через ajax, тогда нет необходимости использовать объект File, нужны только объекты Blob и FormData.

Как я отмечаю, почему бы вам просто не отправить строку base64 на сервер через ajax и преобразовать ее в двоичную серверную часть, используя, например, PHP base64_decode? В любом случае, стандартный код из этого ответа работает в ночных браузерах Chrome 13 и WebKit:

function dataURItoBlob(dataURI) {
    // convert base64 to raw binary data held in a string
    // doesn't handle URLEncoded DataURIs - see SO answer #6850276 for code that does this
    var byteString = atob(dataURI.split(',')[1]);

    // separate out the mime component
    var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];

    // write the bytes of the string to an ArrayBuffer
    var ab = new ArrayBuffer(byteString.length);
    var ia = new Uint8Array(ab);
    for (var i = 0; i < byteString.length; i++) {
        ia[i] = byteString.charCodeAt(i);
    }

    //Old Code
    //write the ArrayBuffer to a blob, and you're done
    //var bb = new BlobBuilder();
    //bb.append(ab);
    //return bb.getBlob(mimeString);

    //New Code
    return new Blob([ab], {type: mimeString});


}

Затем просто добавьте BLOB-объект к новому объекту FormData и опубликуйте его на своем сервере, используя ajax:

var blob = dataURItoBlob(someDataUrl);
var fd = new FormData(document.forms[0]);
var xhr = new XMLHttpRequest();

fd.append("myFile", blob);
xhr.open('POST', '/', true);
xhr.send(fd);
39 голосов
/ 23 мая 2015

BlobBuilder устарел и больше не должен использоваться. Используйте Blob вместо старого BlobBuilder. Код очень чистый и простой.

Файловый объект наследуется от объекта Blob. Вы можете использовать оба из них с объектом FormData.

function dataURLtoBlob(dataurl) {
    var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    while(n--){
        u8arr[n] = bstr.charCodeAt(n);
    }
    return new Blob([u8arr], {type:mime});
}

используйте функцию dataURLtoBlob () для преобразования dataURL в blob и отправки ajax на сервер.

например:

var dataurl = 'data:text/plain;base64,aGVsbG8gd29ybGQ=';
var blob = dataURLtoBlob(dataurl);
var fd = new FormData();
fd.append("file", blob, "hello.txt");
var xhr = new XMLHttpRequest();
xhr.open('POST', '/server.php', true);
xhr.onload = function(){
    alert('upload complete');
};
xhr.send(fd);

Другой способ:

Вы также можете использовать fetch для преобразования URL-адреса в файловый объект (объект file имеет свойство name / fileName, это отличается от объекта blob)

Код очень короткий и простой в использовании. (works in Chrome and Firefox)

//load src and convert to a File instance object
//work for any type of src, not only image src.
//return a promise that resolves with a File instance

function srcToFile(src, fileName, mimeType){
    return (fetch(src)
        .then(function(res){return res.arrayBuffer();})
        .then(function(buf){return new File([buf], fileName, {type:mimeType});})
    );
}

Пример использования 1: просто преобразовать в файловый объект

srcToFile(
    'data:text/plain;base64,aGVsbG8gd29ybGQ=',
    'hello.txt',
    'text/plain'
)
.then(function(file){
    console.log(file);
})

Пример использования 2: преобразование в файловый объект и загрузка на сервер

srcToFile(
    'data:text/plain;base64,aGVsbG8gd29ybGQ=',
    'hello.txt',
    'text/plain'
)
.then(function(file){
    console.log(file);
    var fd = new FormData();
    fd.append("file", file);
    return fetch('/server.php', {method:'POST', body:fd});
})
.then(function(res){
    return res.text();
})
.then(console.log)
.catch(console.error)
;
0 голосов
/ 23 августа 2016

После некоторого исследования я прибыл на это:

function dataURItoBlob(dataURI) {
    // convert base64 to raw binary data held in a string
    // doesn't handle URLEncoded DataURIs - see SO answer #6850276 for code that does this
    var byteString = atob(dataURI.split(',')[1]);
    // separate out the mime component
    var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];
    // write the bytes of the string to an ArrayBuffer
    var ab = new ArrayBuffer(byteString.length);
    var dw = new DataView(ab);
    for(var i = 0; i < byteString.length; i++) {
        dw.setUint8(i, byteString.charCodeAt(i));
    }
    // write the ArrayBuffer to a blob, and you're done
    return new Blob([ab], {type: mimeString});
}

module.exports = dataURItoBlob;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...