以编程方式将输入 type="file" 值设置为 base64 图像?

Programmatically set input type="file" value to base64 image?

我知道出于安全原因,无法以编程方式将本地文件设置为输入字段的文件。 假设我将此图像作为 base64:

var bus = "";

我想以编程方式将其设置为输入类型文件。请不要建议将其作为字符串发送到服务器,因为我无法控制另一端的 API。

我尝试在我的代码中将其转换为 blob 并将其设置为输入字段:

myInputField.value = blob;

但它抛出安全异常:

Uncaught DOMException: Failed to set the 'value' property on 'HTMLInputElement': This input element accepts a filename, which may only be programmatically set to the empty string.

可以通过 javascript 吗?我决不想涉及文件选择器对话框。

谢谢。

不可能。 HTML 文件输入只能指向计算机上实际存在的文件 -- 它不能指向任意数据块。

不,你不能设置文件输入的值*,除了清除它,但听起来这不是你需要的。
相反,将此 dataURI 转换为 Blob,然后将此 Blob 附加到 FormData,最后附加 post 此 FormData。

您的图片将按照您的需要分批发送。

function dataURItoBlob(data) {
  var binStr = atob(data).split(',')[1],
   len = binStr.length,
   arr = new Uint8Array(len);

  for (var i = 0; i < len; i++) {
    arr[i] = binStr.charCodeAt(i);
  }
  return new Blob(arr);
}

var dataURI = 'data:image/....';
var blob = dataURItoBlob(dataURI);

// you can even pass a <form> in this constructor to add other fields
var formData = new FormData(); 
formData.append('yourFileField', blob, 'fileName.ext');

var xhr = new XMLHttpRequest();
xhr.open('post', yourServer);
xhr.send(formData);

// now you can retrieve your image as a File/multipart with the 'yourFileField' post name

*实际上现在 ,但它仍然相当老套。

你可以试试下面的方法。将您的 sting 转换为 Blob 并使用创建的 Blob 创建文件类型。

var debug = {hello: "world"};
var blob = new Blob([JSON.stringify(debug, null, 2)], {type : 'application/json'});

var outputfile=new File([blob], "filename")