how to detect the MIME type of data URL

pavithra rox picture pavithra rox · Jan 26, 2018 · Viewed 9k times · Source

I'm developing an angular 4 application. I have a base64 encoded image. I'm saving it in the file system with node.js.

 if (body.profilepic != "") {
            let base64Data = body.profilepic.split(';base64,').pop();

            fs.writeFile("out.png", base64Data, 'base64', function(err) {
                if (!err) {
                    console.log("saved file")
                }
            });
        }

The thing is that I can't detect the file type of the image I'm saving. right now it only saves pngs.

How do I detect the file type of the image string I'm receiving?

The base64 encoded string I'm getting is something like this:



Answer

efkan picture efkan · Mar 1, 2018

Extracting the content (MIME) type from a full base64 content.

const base64Content = ""
    
// base64 encoded data doesn't contain commas    
let base64ContentArray = base64Content.split(",")     
   
// base64 content cannot contain whitespaces but nevertheless skip if there are!
let mimeType = base64ContentArray[0].match(/[^:\s*]\w+\/[\w-+\d.]+(?=[;| ])/)[0]

// base64 encoded data - pure
let base64Data = base64ContentArray[1]

console.log("base64Content: ", base64Content)
console.log("mimeType: ", mimeType)
console.log("base64Data: ", base64Data)