我知道本地文件无法以编程方式设置为输入字段的安全原因。 假设我将此图像作为base64:
var bus = "";
我想以编程方式将其设置为输入类型文件。请不要建议将此字符串作为字符串发送到服务器,因为我无法在另一端控制API。
我尝试在代码中将其转换为blob,并将其设置为输入字段:
myInputField.value = blob;
但它会引发安全异常:
未捕获的DOMException:无法在'HTMLInputElement'上设置'value'属性:此input元素接受一个文件名,该文件名只能以编程方式设置为空字符串。
是否可以通过javascript?我绝不想涉及文件选择器对话框。
谢谢。
答案 0 :(得分:2)
不可能。 HTML文件输入只能指向计算机上实际存在的文件 - 它不能指向任意数据块。
答案 1 :(得分:1)
没有你不能设置文件输入值 *,除了清除它,但听起来它不是你需要的。
相反,将此dataURI转换为Blob,然后将此Blob附加到FormData并最终发布此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
*实际上现在you can do it,但它仍然相当hackish。
答案 2 :(得分:1)
你可以尝试下面的一个。将您的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")