特定のバージョンの BLOB への読み取りアクセスを許可するために、BLOB バージョン SAS を生成しようとしています。SAS 生成をルート BLOB に対して機能させ、BlobVersionId を追加して BLOB のバージョン管理機能用に変更しようとしましたが、サーバーから 403 が返されました。
特定の BLOB バージョン用に変更された SAS Builder: (動作していません)
public string GetBlobSasTokenAsync(string containerName, string blobName, string blobVersionId, string fileName)
{
var sasBuilder = new BlobSasBuilder()
{
BlobContainerName = containerName,
BlobName = blobName,
BlobVersionId = blobVersionId,
StartsOn = DateTime.UtcNow.Subtract(_clockSlew),
ExpiresOn = DateTime.UtcNow.AddMinutes(AccessDuration) + _clockSlew,
ContentDisposition = "inline; filename=" + fileName,
ContentType = GetContentType(fileName)
};
sasBuilder.SetPermissions("r");
var storageSharedKeyCredential = new StorageSharedKeyCredential(_accountName, _accountKey);
var sasQueryParameters = sasBuilder.ToSasQueryParameters(storageSharedKeyCredential);
return sasQueryParameters.ToString();
}
エラー:
<?xml version="1.0" encoding="utf-8"?>
<Error>
<Code>AuthenticationFailed</Code>
<Message>Server failed to authenticate the request. Make sure the value of Authorization header is formed correctly including the signature.
RequestId:63b83bb8-201e-00a8-55a1-544fe3000000
Time:2020-07-07T21:01:08.2149986Z</Message>
<AuthenticationErrorDetail>The specified signed resource is not allowed for the this resource level</AuthenticationErrorDetail>
</Error>
使用: Azure.Storage.Blobs 12.5.0-preview.5