Introduction
In this blog I have explained how to upload any file to Azure Blob Storage using Microsoft Power Automate (Flow).
Solution
We will use Base64 string as file content. To trigger this flow, I have created HTTP POST request so that, we can call it in any programming language. You can use any other trigger as per your requirement.
Step by Step
- Go to https://flow.microsoft.com and login with your credentials.
- Click on My Flows > New > Instant–from Blank.
data:image/s3,"s3://crabby-images/5c240/5c24015b72977a22b395629abe8233f1da1cef66" alt="SAS URI to access file from Azure Blob Storage using MS Flow"
- If you are shown list of triggers, click on Skip.
data:image/s3,"s3://crabby-images/da9d2/da9d25dd8647eb568a5712d54da60a3211afaac7" alt="SAS URI to access file from Azure Blob Storage using MS Flow"
- Search “HTTP request” in search box and select “When an HTTP request is received”
data:image/s3,"s3://crabby-images/a5905/a59058c56d35b07ddf8bb070c02a2baeaff17ea5" alt="SAS URI to access file from Azure Blob Storage using MS Flow"
- Then write a JSON object which will contain 3 variables for path, file name and file content. Here path is the “container” of the Azure Blob Storage.
data:image/s3,"s3://crabby-images/872d4/872d40f7828ad061530f19d4ee1ce268cfca742d" alt="Upload to ABS"
- In flow you will find lot of azure blob storage action. Here we are uploading a file to azure blob storage, then you must add next step as a “Create blob” action.
data:image/s3,"s3://crabby-images/483a4/483a46c74864fdae87711ea279a685973b74b1e1" alt="SAS URI to access file from Azure Blob Storage using MS Flow"
data:image/s3,"s3://crabby-images/5798c/5798cf46fd9b270705984e4544687a3441fa938b" alt="Upload to ABS"
- But to add this action you need to create a connection with “Azure Blob Storage” by providing necessary credentials.
data:image/s3,"s3://crabby-images/859c8/859c8d6f4479aad18e036991cae56d90d6e9db6b" alt="SAS URI to access file from Azure Blob Storage using MS Flow"
- Set “Folder path” and “Blob name” fields as below.
data:image/s3,"s3://crabby-images/031ad/031ad8cc8348838d2beda488ecd08b2a227beab2" alt="Upload to ABS"
- Here is the main issue. We cannot pass base64 string directly to “Blob content” field as content. This field required binary datatype value. So, we must convert base64 string to binary. Here MS Flow provide us a function to convert base64 string to binary without any code. To use it, follow below steps.
data:image/s3,"s3://crabby-images/ea441/ea441b0452a2a71d0958533cdb624433d176f8c2" alt="Upload to ABS"
- Add opening and closing brackets after expression then you will a notification text to inform you about variable to pass this expression.
data:image/s3,"s3://crabby-images/0f576/0f576e3afd536a94317b5ae66bd1b04e5a2d16b0" alt="Upload to ABS"
- Click on “Dynamic content” tab and select appropriate variable.
data:image/s3,"s3://crabby-images/8d504/8d504de0db3b2a3643e4a24364cac423af65597b" alt="Upload to ABS"
- You will see final expression as “base64ToBinary(triggerBody()?[‘blobcontent’])”
- Click on “OK”.
- You will see “Blob Content” field is now populated.
data:image/s3,"s3://crabby-images/9d42a/9d42a53f19ca62fd7f6fc79c6270c50d50bd9a77" alt="Upload to ABS"
- Now you must add new step to send response. To do that, click on new step, search for “Request”, click on “Request” and select “Response” action.
data:image/s3,"s3://crabby-images/4696a/4696a4d208ee95ae86bfd0431bb066b71004b1b4" alt="SAS URI to access file from Azure Blob Storage using MS Flow"
- In response action, in Body filed select “path” variable which is an output variable of “Create Blob” step. Please search for “Path” in dynamic content if you don’t see path variable directly.
data:image/s3,"s3://crabby-images/2dbb5/2dbb5112a248e83a7bacf3772ed272897d3dd2ce" alt="Upload to ABS"
- Here path is the link location of the file uploaded on Azure Blob Storage.
- In addition, when you are updating the same file with different file content, then you must use “Update Blob” action which take file location link start from container as path and file content.
- Example for the path : if file location is this ”https://azureblob.windows.net/xyz/files/filename.png“ then path is like this “xyz/files/filename.png”.
data:image/s3,"s3://crabby-images/5bbb2/5bbb2f77264563c6df456f4bc497df3e55478992" alt="Upload to ABS"
You’re awesome!
Thanks a lot, this post saved me hours.
Hello, can the flow handle large files? example: If I want to upload a video 3GB with high quality do the flow will be capable to create it in Azure Blob with a short time?
You can read about the limits here :https://learn.microsoft.com/en-us/power-automate/limits-and-config