Azure Blob Storage: BlobClient name causing issues when generating SAS token
See original GitHub issueTrying to generate SAS tokens for blobs that are stored in Azure Blob Storage, using the Azure.Storage.Blobs.BlobClient and Azure.Storage.Sas.BlobSasBuilder. Provided the BlobClient’s Name property to BlobSasBuilder’s BlobName property. This only works as long as there is no character that will be URL-encoded in the blob name, e.g. a blankspace.
I would expect the BlobClient.Name to return the blob name without any encoding.
Using BlobClient.Name for the SAS-token will generate a URI that is invalid if used.
<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:7b5be14d-d01e-0052-3bbc-401398000000 Time:2020-06-12T13:24:49.0110739Z
</Message>
<AuthenticationErrorDetail>
Signature did not match. String to sign used was r 2020-06-12T13:23:26Z 2020-06-12T14:23:26Z /blob/xxx/files/a0958aeb-3de7-430f-a94b-88314be31f26/test (2).txt https 2019-07-07 b
</AuthenticationErrorDetail>
</Error>
To Reproduce: I realize that the BlobClient isn’t necessary in below example. It would be more valid if the method were to say, upload a blob and return the SAS URI.
// Called with:
// id = "a0958aeb-3de7-430f-a94b-88314be31f26"
// fileName = "test (2).txt"
public string GetBlobUri(Guid id, string fileName)
{
var blobName = $"files/{id}/{fileName}";
var blobClient = _containerClient.GetBlobClient(blobName);
var sas = new BlobSasBuilder
{
BlobContainerName = _containerClient.Name,
BlobName = blobClient.Name, // will be "files/a0958aeb-3de7-430f-a94b-88314be31f26/test%20(2).txt" instead of "files/a0958aeb-3de7-430f-a94b-88314be31f26/test (2).txt"
Resource = "b",
StartsOn = DateTimeOffset.UtcNow,
ExpiresOn = DateTimeOffset.UtcNow.AddHours(1),
Protocol = SasProtocol.Https,
};
sas.SetPermissions(BlobSasPermissions.Read);
var sasUri = new UriBuilder(blobClient.Uri)
{
Query = sas.ToSasQueryParameters(_sharedKeyCredential).ToString()
};
return sasUri.ToString();
}
Package:
- Azure.Storage.Blobs 12.4.1
Issue Analytics
- State:
- Created 3 years ago
- Comments:5 (3 by maintainers)
Top Results From Across the Web
Troubleshoot client application errors in Azure Storage ...
This issue may arise if you generate SAS tokens with a long expiry time for client applications to cache.
Read more >Azure Blob Storage fails to authenticate: "Make sure the ...
Azure Blob Storage fails to authenticate: "Make sure the value of Authorization header is formed correctly including the signature".
Read more >Azure Blob Container, Can't Generate Token
I'm working on azure storage but I cannot create a proper SAS token to pass to my frontend javascript. Following multiple tutorials and...
Read more >Generate SAS Token For Azure Blob Storage Using ...
This article demonstrates how to generate user delegation shared access signature (SAS) tokens for an Azure Blob.
Read more >Azure Storage Blob client library for Java - Microsoft .NET
SAS Token · Go to your Storage Account · Select Shared access signature from the menu on the left · Click on Generate...
Read more >Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start FreeTop Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
Top GitHub Comments
Related to #12837
So scratch what I said before.
Looks like since the behavior on encoding the name isn’t consistent between using GetBlobClient and making a new BlobClient. So since it’s clearly a regression and bug, it’s not a breaking change and we can change it back to not an encoded Name.
We will look to get this fixed soon.
Awesome, thank you for the update.