我可能在这里遗漏了一些简单的东西,但是鉴于从 AJAX 请求接收到的二进制数据,我将如何在 JavaScript 中创建 File 对象?
$.ajax({
url: "http://example.com/image.jpg",
success: function(data) {
// Convert binary data to File object
}
});
我可能在这里遗漏了一些简单的东西,但是鉴于从 AJAX 请求接收到的二进制数据,我将如何在 JavaScript 中创建 File 对象?
$.ajax({
url: "http://example.com/image.jpg",
success: function(data) {
// Convert binary data to File object
}
});
我终于想通了。为了避免跨站点脚本问题,我在我的服务器上创建了一个代理端点。然后我可以将图像 URL 传递给我的服务器,然后服务器对远程文件执行 GET 请求,将响应转换为 Base64,并将其发送回浏览器。然后,浏览器可以将数据转换回二进制文件并创建一个 Blob(就我的目的而言,它与 File 一样好)。
$.ajax({
url: apiRoot + "/proxy",
data: {url: "http://example.com/image.jpg"},
success: function(data) {
var binary = atob(data.split(',')[1]);
var array = [];
for (var i = 0; i < binary.length; i++) {
array.push(binary.charCodeAt(i));
}
var file = new Blob([new Uint8Array(array)], {type: 'image/jpeg'});
}
});