我们已经在Azure存储上创建了一个文件夹结构,如下所示:
parentcontainer -> childcontainer -> {pdffiles are uploaded here}
我们具有存储的.pdf
文件的URL。我们不想硬编码任何容器名称,只需使用其URL下载文件即可。
我们当前的尝试:
CloudStorageAccount cloudStorageAccount = CloudStorageAccount.Parse(StorageConnectionString);
CloudBlobClient blobClient = cloudStorageAccount.CreateCloudBlobClient();
CloudBlobContainer cloudBlobContainer = blobClient.GetRootContainerReference();
CloudBlockBlob blockBlob = cloudBlobContainer.GetBlockBlobReference(pdfFileUrl);
var blobRequestOptions = new BlobRequestOptions
{
RetryPolicy = new NoRetry()
};
// Read content
using (MemoryStream ms = new MemoryStream())
{
blockBlob.DownloadToStream(ms, null, blobRequestOptions);
var array = ms.ToArray();
return ms.ToArray();
}
但是我们在这里收到“ 400错误请求”:
blockBlob.DownloadToStream(ms, null, blobRequestOptions);
我们如何仅使用URL下载Azure BLOB存储文件?
答案 0 :(得分:4)
Navigator.of(context).pop
将文件名作为其构造函数的参数,而不是URL。
要通过URL下载Azure BLOB存储项目,您需要使用该项目的URL自己实例化一个GetBlockBlobReference
:
var blob = new CloudBlockBlob(new Uri(pdfFileUrl), cloudStorageAccount.Credentials);
然后可以使用您最初发布的代码下载此blob
。