使用拖放区将文件直接上传到 Azure Blob 存储(使用 SAS).js
Upload file directly to Azure Blob Storage (with SAS) using dropzone.js
我想使用dropzone.js将文件直接上传到Azure Blob存储,并使用SAS(此处的示例)将文件保密。
据我了解,工作流程将是:
- 用户选择一个文件
- 放置区
processing
事件将触发。在事件处理程序中,我在站点的 API 上调用一个方法,该方法创建要上传到的 Azure Blob URI,包括 SAS 查询字符串 - 拖放区上传 URL 设置为"安全"blob URL
- 上传开始
我找到了以下维基文章,展示了如何动态设置拖放区 URL(https://github.com/enyo/dropzone/wiki/Set-URL-dynamically)
Dropzone.options.myDropzone = {
init: function() {
this.on("processing", function(file) {
// I need to do an async call here, to get the URL...
this.options.url = "/some-other-url";
});
}
};
问题是上面的例子是同步的。如何延迟上传,直到从我的 Web API 异步请求 URL?
谢谢
可能是我回答得有点晚了
使用预定义的 SAS
只需在呈现页面时将其保存在具有data-sas
属性form
元素中即可。我看到的唯一缺点 - 如果页面有一段时间没有刷新,您的 SAS 可能会过期。这是我的工作代码的一部分(其他变体来自我的头脑)
Dropzone.options.myDropzone = {
method: "PUT",
headers: {"x-ms-blob-type": "BlockBlob"},
sending: (file, xhr) => {
// To send file without wrappintng it to multipart/form-data,
// Azure won’t unwrap it
const _send = xhr.send;
xhr.send = () => { _send.call(xhr, file) };
},
init: function() {
const dz = this,
action = dz.element.action,
sas = dz.element.dataset.sas;
dz.on("processing", (file) => {
dz.options.headers["Content-Type"] = file.type;
dz.options.url = `${action}/${file.name}?${sas}`;
})
},
}
在Dropzone的init
中使用异步调用
Dropzone.options.myDropzone = {
autoProcessQueue: false, // To prevent automatic auploading before getting SAS
acceptedFiles: ".xls,.xlsx",
method: "PUT",
headers: {"x-ms-blob-type": "BlockBlob"},
sending: (file, xhr) => {
// To send file without wrappintng it to multipart/form-data,
// Azure won’t unwrap it
const _send = xhr.send;
xhr.send = () => { _send.call(xhr, file) };
},
init: function() {
let sas = null;
const dz = this,
xhr = new XMLHttpRequest();
xhr.addEventListener("load",
(event) => {
sas = getSasFromEvent(event);
dz.options.autoProcessQueue = true;
dz.processQueue();
}, true);
xhr.open("GET", "/get-sas");
xhr.send();
dz.on("processing", (file) => {
dz.options.headers["Content-Type"] = file.type;
dz.options.url = `${action}/${file.name}?${sas}`;
})
},
}
在获得 SAS 异步后运行 Dropzone
请参阅以编程方式创建放置区
你可以尝试使用 jQuery 进行同步 ajax 调用。
function GetUrl() {
var url = "";
$.ajax({
async: false,
success: function(data) {
url = data;
}
// Other opts
});
return url;
}
Dropzone.options.myDropzone = {
init: function() {
this.on("processing", function(file) {
this.options.url = GetUrl();
});
}
};
相关文章:
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- Fin上传器直接上传到Azure Blob存储-在Javascript中获取文件uri
- 是否可以将音频存储为javascript/jQuery中的blob数据
- Javascript下载一个URL-Azure Blob存储
- 如何在没有Ajax的情况下将blob存储在表单中,并在单击提交时将其发送到服务器
- 如何使用forge加密和解密pdf blob并存储在localStorage中
- Azure Blob 存储 请求的资源错误中不存在访问控制允许源标头
- 使用拖放区将文件直接上传到 Azure Blob 存储(使用 SAS).js
- 打印存储为BLOB的不同文件格式的最优雅方式
- 从js上传一个图像文件到azure blob存储
- 将文件从客户端上载到Azure Blob存储|MVC
- 检索作为blob存储在数据库中的图片,并将其显示在html中
- HTML5 -大Blob和持久的本地存储
- 如何使用javascript上传图像到azure blob存储
- Javascript文件阅读器在存储到内存-参数1不是类型'Blob'
- 如何正确使用nodejs和javascript在mysql中存储blob数据
- Azure存储blob REST API: MAC签名不同于Azure计算签名(缺少内容类型)
- 如何发送一个文件从html页面使用ajax到php,这反过来存储在mysql数据库的列类型BLOB
- 使用Intel XDK将图像从PhoneGap上载到Azure Blob存储
- Blob 二进制数据存储在哪里