Как преобразовать dataURL в файл объекта в JavaScript?
Мне нужно преобразовать dataURL в объект File в Javascript, чтобы отправить его с помощью AJAX. Является ли это возможным? Если да, пожалуйста, скажите мне, как.
6 ответов
Если вам нужно отправить его через 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);
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-адреса в объект файла (объект файла имеет свойство 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)
;
Чтобы создать большой двоичный объект из dataURL:
const blob = await (await fetch(dataURL)).blob();
Чтобы создать файл из большого двоичного объекта:
const file = new File([blob], 'fileName.jpg', {type:"image/jpeg", lastModified:new Date()});
Если вы действительно хотите преобразовать dataURL в
File
объект.
Вам нужно преобразовать dataURL в
Blob
затем преобразовать
Blob
в
File
. Функция взята из ответа Мэтью. ( /questions/6227170/kak-preobrazovat-dataurl-v-fajl-obekta-v-javascript/6227172#6227172)
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);
}
return new Blob([ab], { type: mimeString });
}
const blob = dataURItoBlob(url);
const resultFile = new File([blob], "file_name");
Помимо этого, у вас могут быть варианты на
File
Объект инициализирован. Ссылка на конструктор File().
const resultFile = new File([blob], "file_name",{type:file.type,lastModified:1597081051454});
Тип должен быть
[MIME][1]
тип (т.е.
image/jpeg
) и последнее измененное значение в моем примере эквивалентно
Mon Aug 10 2020 19:37:31 GMT+0200 (Eastern European Standard Time)
После некоторых исследований я пришел к этому:
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;