Azure Blob SAS和缓存控制,以确保缓存资源

2022-03-04 00:00:00 azure azure-blob-storage caching html

我们提供的是私有资源(图像、文件.)存储在Azure Blob容器中。

安全性使用Shared Access Signatures实现,为每个对资源的请求创建,例如,两个请求意味着两个不同的访问令牌。

通常安全URL由文件名组成,令牌作为查询字符串传递,例如https://myaccount.blob.core.windows.net/file.img?sv=2015-04-05&ss=bf&srt=s&st=2015-04-29T22%3A18%3A26Z&se=2015-04-30T02%3A23%3A26Z&sr=b&sp=rw&sip=168.1.5.60-168.1.5.70&spr=https&sig=F%6GRVAZ5Cdj2Pw4tgU7IlSTkWgn7bUkkAg8P6HESXwmf%4B

资源的响应包含缓存控制头(缓存控制:MAX-AGE=31536000?

使用常规HTML或元素在网站中显示图像和视频类型的资源。

以这种方式提供的资源是否可以由浏览器缓存?

谢谢大家!


解决方案

可以将缓存头添加到共享访问签名。

这将指示Azure Blob将相应的缓存头作为HTTP响应的一部分返回。

这就是如何用c#:

    var policy = new SharedAccessBlobPolicy();
    var headers = new SharedAccessBlobHeaders() { CacheControl = "max-age=" + MaxCacheAgeInDays * 24 * 60 * 60 };
    var blockBlob = _container.GetBlockBlobReference(name);

    var result = _baseUrl + blobName + blockBlob.GetSharedAccessSignature(policy, headers);

希望这能帮助其他人。

ps:可以对其他HTTP标头执行相同的操作。

相关文章