Как загрузить изображение base64 для ввода типа файла?

У меня есть вход:

<input id="imagen" name="imagen[]" type="file" multiple class="file-loading" onchange="">

И у меня есть кнопка сканирования

<button type="button" class="btn btn-success" onclick="scannear()"><i class="fa fa-print"></i> Escanear</button>

Эта кнопка открывает гнездо подключения к моему сканеру и извлекает изображение в Base64, оно скажем string, который я хочу загрузить в мой тип файла ввода, как я могу это сделать?

Чтобы быть понятнее, если у меня есть строка:

var cadena="";

Как назначить это значение для ввода типа файла?

1
задан 22.11.2019, 19:02
1 ответ

Из-за razГіn безопасности не возможно загружать вручную файл в <input type="file">

год Но, если envГ-схвати данные используя AJAX, тогда мы можем использовать это, чтобы посылать изображение как файл, без необходимости использовать один input file.

Пример:

  • С API fetch, чтобы обращать цепь base64 в blob.
  • Мы Используем File, чтобы создавать blob файл.
  • И с FormData, получать данные о формуляре, добавлять вручную файл

Тогда, когда мы получаем изображение в base64, мы обращаем ее в "файл"

var image = "...";
var files = [];

fetch(image)
  .then(res => res.blob())
  .then(blob => {
    files.push(new File([blob], 'image.jpeg', {type: blob.type}));
 })

Потом, когда формуляр послан, получаем данные, загруженные в этом и добавляем вручную файл:

Используя чистые Javascript:

var form = document.getElementById('id-del-form');
form.onsubmit = function() {
  var formData = new FormData(form);

  // AQUI agregamos manualmente el archivo
  files.forEach(function(file, idx) {
    formData.append('imagen['+idx+']', file);
  });

  var xhr = new XMLHttpRequest();
  xhr.open('POST', form.getAttribute('action'), true);
  xhr.send(formData);

  return false; // Evitamos que el formulario se envíe
}

Используя jQuery:

var $form = $('#id-del-form');
$form.on('submit', function(e) {
  e.preventDefault();

  var formData = new FormData($form[0]);

  // AQUI agregamos manualmente el archivo
  files.forEach(function(file, idx) {
    formData.append('imagen['+idx+']', file);
  });

  $.ajax({
    url: $form.prop('action'),
    type: "post",
    data: formData,
    cache: false,
    contentType: false,
    processData: false
  })
});
0
ответ дан 01.12.2019, 10:57

Теги

Похожие вопросы