Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

how to detect the MIME type of data URL

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:


like image 521
pavithra rox Avatar asked Jan 26 '18 05:01

pavithra rox


People also ask

How do I find MIME type?

string mimeType = MimeMapping. GetMimeMapping(fileName); If you need to add custom mappings you probably can use reflection to add mappings to the BCL MimeMapping class, it uses a custom dictionary that exposes this method, so you should invoke the following to add mappings (never tested tho, but should prob. work).

What is MIME type in HTML?

A media type (also known as a Multipurpose Internet Mail Extensions or MIME type) indicates the nature and format of a document, file, or assortment of bytes. MIME types are defined and standardized in IETF's RFC 6838.

What is base64 URL?

Base64 is a group of binary-to-text encoding schemes that represent binary data in an ASCII string format by translating it into a radix-64 representation. By consisting only of ASCII characters, base64 strings are generally url-safe, and that's why they can be used to encode data in Data URLs.

What is data URL in HTML?

A Data URL is a URI scheme that provides a way to inline data in a document, and it's commonly used to embed images in HTML and CSS.


2 Answers

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
like image 85
Pithikos Avatar answered Oct 17 '22 11:10

Pithikos


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)
like image 22
efkan Avatar answered Oct 17 '22 12:10

efkan