Skip to content

Instantly share code, notes, and snippets.

@vipulwairagade
Last active July 25, 2022 08:28
Show Gist options
  • Save vipulwairagade/0070f0647469bf8d273c8568790e5df6 to your computer and use it in GitHub Desktop.
Save vipulwairagade/0070f0647469bf8d273c8568790e5df6 to your computer and use it in GitHub Desktop.
Upload Base64 Image to Azure Blob Storage in Node.js
const azure = require('azure-storage')
const STORAGE_ACCOUNT_NAME = '<Your-Storage-Account-Name>';
const ACCOUNT_ACCESS_KEY = '<Your-Storage-Account-Access-Key>';
const blobSvc = azure.createBlobService(STORAGE_ACCOUNT_NAME, ACCOUNT_ACCESS_KEY)
const containerName = '<Your-Container-Name>'
const image = ''
async function uploadImgToAzure(image) {
return new Promise((resolve, reject) => {
let filename = 'TestImage202.png'
let matchesBlobImg = image.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/);
let imgType = matchesBlobImg[1]
let imgBuffer = new Buffer.from(matchesBlobImg[2], 'base64')
blobSvc.createBlockBlobFromText(containerName, filename, imgBuffer, {
contentSettings: { contentType: imgType }
}, (error, result, response) => {
if (error)
reject(error);
console.log("🚀 ~ uploadImgToAzure ~ response", response)
console.log("🚀 ~ uploadImgToAzure ~ result", result)
const fileUrl = `https://<Your-Storage-Account-Name>.blob.core.windows.net/${containerName}/${filename}`;
resolve(fileUrl)
})
})
}
(async () => {
let fileUrl = await uploadImgToAzure(image)
console.log("🚀 ~ fileUrl", fileUrl)
})().catch(err => {
console.error(err);
});
@IlyaIvanchikov
Copy link

regExp is not goot maybe my example will be better for you?
const [, imgType] = base64Image.split(';')[0].split(':');
const base64 = base64Image.split(',')[1];

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment