javascript – 使用dropzone.js将文件直接上传到Azure Blob存储(使用SAS)
作者:互联网
我想使用dropzone.js将文件直接上传到Azure Blob存储,使用SAS(example here)将文件保密.
据我了解,工作流程将是:
>用户选择一个文件
> dropzone处理事件触发.在事件处理程序中,我在我的站点的API上调用一个方法,该方法创建要上载的Azure Blob URI,包括SAS查询字符串
> dropzone上传URL设置为“安全”blob URL
>上传开始
我找到了以下wiki文章,展示了如何动态设置dropzone 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,我该如何延迟上传?
谢谢
解决方法:
您可以尝试使用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();
});
}
};
标签:javascript,azure,dropzone-js,azure-storage-blobs 来源: https://codeday.me/bug/20190623/1270198.html