使用 SAS 从 Azure Blob Storage 下载文件到浏览器

Downloading file to browser from Azure Blob Storage using SAS

在我的 DownloadFile 页面的 Page_Load 方法中,用户希望下载的文件名是从查询字符串中检索的。该文件托管在 Azure Blob 存储帐户中。我正在尝试通过这种方法使用共享访问签名 (SAS) 下载文件:

var containerName = "containerName";
var con = "connectionString";
CloudStorageAccount account = CloudStorageAccount.Parse(con);

var blobClient = account.CreateCloudBlobClient();
var container = blobClient.GetContainerReference(containerName);
var blob = container.GetBlockBlobReference("file.pdf");
var sasToken = blob.GetSharedAccessSignature(new SharedAccessBlobPolicy()
{
    Permissions = SharedAccessBlobPermissions.Read,
    SharedAccessExpiryTime = DateTime.UtcNow.AddMinutes(10),
}, new SharedAccessBlobHeaders()
{
    ContentDisposition = "attachment; filename=file.pdf"
});

var blobUrl = string.Format("{0}{1}", blob.Uri.AbsoluteUri, sasToken);
Response.Redirect(blobUrl);

但是,这不会下载文件。相反,浏览器只是显示文件的乱码流:

blobUrl 似乎有效。但是 Response.Redirect 没有按预期工作。我做错了什么吗?

注意:我正在使用 WebForms(不幸的是),不是 MVC

我能够通过使用 iframe 找出解决方法。如果我在页面中添加 iframe

<iframe id="iframeFile" runat="server" style="display:none;"></iframe>

然后在代码文件中设置源代码:

iframeFile.Src = blobUrl;

下载文件。

这可能不太理想,我仍然不确定为什么 Response.Redirect 没有按预期工作。所以我当然也愿意接受其他建议。但此解决方法确实解决了无法下载文件的问题。