how to detect the MIME type of data URL
Asked Answered
O

5

12

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:


Overeager answered 26/1, 2018 at 5:18 Comment(4)
What is body.profilepic?Hokkaido
The base64 string shows the format within the string. data:image/gif;base64 Exaple data:image/ Format ;base64 When the comment before had been posted I thought I has read the question wrong and removed my comment but then I remembered seeing body.profilepic.split(';base64,').pop(); so you can so the same thing to get the format. from the string.Natter
@Hokkaido that is the variable that contain the base64 stringOvereager
@Natter i have updated my post please seeOvereager
A
21

You don't need regex or anything fancy.

The dataUrl has a very predictible format and we know that mime is going to be in the very beginning. So it's fine to stop in the first occurences of ':' and ';'.

dataUrl = ".."
dataUrl.substring(dataUrl.indexOf(":")+1, dataUrl.indexOf(";"))  // => image/png
Attalanta answered 15/5, 2020 at 20:33 Comment(0)
I
12

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)
Ikkela answered 1/3, 2018 at 9:31 Comment(1)
I've read that you should avoid regex in production apps at any cost.Gesture
H
0

You can use RegExp /[^:]\w+\/[\w-+\d.]+(?=;|,)/ to match one or more word characters preceded by :, followed by /, followed by one or more word characters in a character set including - character to handle application/octet-stream, + to handle image/svg+xml, \d to handle application/x-7z-compressed, . to handle application/vnd.apple.mpegurl followed by ; or , character to handle base64 not being included in the data URL

const body = {profilepic:""};

let mimeType = body.profilepic.match(/[^:]\w+\/[\w-+\d.]+(?=;|,)/)[0];

console.log(mimeType);
Hokkaido answered 26/1, 2018 at 5:33 Comment(0)
F
-1
const obj = /data:(.*);base64,(.*)/.exec('');

console.log('MIME Type: ' + obj[1]);
console.log('Base64 data: ' + obj[2]);

Or from IMG tag:

const obj = /<img.*src="data:(.*);base64,(.*?)"/.exec('<img src="" />');

console.log('MIME Type: ' + obj[1]);
console.log('Base64 data: ' + obj[2]);
Fransen answered 10/7, 2019 at 14:56 Comment(0)
R
-1

if you want to get Mime type like (image/png), (image/jpg) use this one

const body = {profilepic:""};
let mimeType = body.profilepic.match(/[^:]\w+\/[\w-+\d.]+(?=;|,)/)[0];

online Demo here

===========================================

if you want to get only type of it like (png, jpg) etc

const body2 = {profilepic:""};
let mimeType2 = body2.profilepic.match(/[^:/]\w+(?=;|,)/)[0];

online Demo here

Reni answered 2/10, 2019 at 6:37 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.