Last active
          May 17, 2025 22:52 
        
      - 
      
- 
        Save topalex/ad13f76150e0b36de3c4a3d5ba8dc63a to your computer and use it in GitHub Desktop. 
    How to check real mime type of image in javascript
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | <!DOCTYPE html> | |
| <html lang="en"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <title>Mime type checker</title> | |
| <script type="text/javascript" src="/jquery.min.js"></script> | |
| <script> | |
| $(function () { | |
| var result = $('div#result'); | |
| if (window.FileReader && window.Blob) { | |
| $('span#submit').on('click', function () { | |
| var files = $('input#file').get(0).files; | |
| if (files.length > 0) { | |
| var file = files[0]; | |
| console.log('Loaded file: ' + file.name); | |
| console.log('Blob mime: ' + file.type); | |
| var fileReader = new FileReader(); | |
| fileReader.onerror = function (e) { | |
| console.error('ERROR', e); | |
| }; | |
| fileReader.onloadend = function (e) { | |
| var arr = new Uint8Array(e.target.result); | |
| var header = ''; | |
| for (var i = 0; i < arr.length; i++) { | |
| header += arr[i].toString(16); | |
| } | |
| console.log('File header: ' + header); | |
| // Check the file signature against known types | |
| var type = 'unknown'; | |
| switch (header) { | |
| case '89504e47': | |
| type = 'image/png'; | |
| break; | |
| case '47494638': | |
| type = 'image/gif'; | |
| break; | |
| case 'ffd8ffe0': | |
| case 'ffd8ffe1': | |
| case 'ffd8ffe2': | |
| type = 'image/jpeg'; | |
| break; | |
| case '25504446': | |
| type = 'application/pdf'; | |
| break; | |
| } | |
| if (file.type !== type) { | |
| result.html('<span style="color: red; ">Mime type detected: ' + type + '. Does not match file extension.</span>'); | |
| } else { | |
| result.html('<span style="color: green; ">Mime type detected: ' + type + '. Matches file extension.</span>'); | |
| } | |
| }; | |
| fileReader.readAsArrayBuffer(file.slice(0, 4)); | |
| } | |
| }); | |
| } else { | |
| result.html('<span style="color: red; ">Your browser is not supported. Sorry.</span>'); | |
| console.error('FileReader or Blob is not supported by browser.'); | |
| } | |
| }); | |
| </script> | |
| <style> | |
| .submit { | |
| border: 1px grey solid; | |
| padding: 3px; | |
| position: relative; | |
| top: 10px; | |
| cursor: pointer; | |
| } | |
| </style> | |
| </head> | |
| <body> | |
| Check mime type of your file in one click<br> | |
| <input type="file" id="file"><br> | |
| <div id="result"></div> | |
| <span class="submit" id="submit">Check</span> | |
| </body> | |
| </html> | 
Do you know if there's a way to get the header without reading the entire file? My users have low end devices
Do you know if there's a way to get the header without reading the entire file? My users have low end devices
Yeah, we need just first 4 bytes to test for common types
So I've updated this gist, the answer is on line #55
Ah! fantastic, thanks a million.
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
You are my hero! 🦸🏻♂️