最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - js check if an image truncatedcorrupted data - Stack Overflow

programmeradmin4浏览0评论

I'm looking for how to detect an image data is truncated\corrupted. For example this picture:

the data image is not complete (It's more tangible on IE, and its noted as warning in firefox console), but img.onerror not fired, and imgpleted is true.

demo: /

var img = document.getElementById('MyPicture');

img.onerror = () => alert('error img');  
img.onload = () =>  console.log(imgplete); //true

img.src = ".jpg";

I want a way to know that. if an image have invalid data.

I'm looking for how to detect an image data is truncated\corrupted. For example this picture:

the data image is not complete (It's more tangible on IE, and its noted as warning in firefox console), but img.onerror not fired, and img.completed is true.

demo: https://jsfiddle.net/7dd0ybb4/

var img = document.getElementById('MyPicture');

img.onerror = () => alert('error img');  
img.onload = () =>  console.log(img.complete); //true

img.src = "https://i.sstatic.net/nGkok.jpg";

I want a way to know that. if an image have invalid data.

Share Improve this question edited Jan 6, 2017 at 8:50 dovid asked Jan 4, 2017 at 10:55 doviddovid 6,4624 gold badges34 silver badges77 bronze badges 12
  • The reason is 'coz the image is completely loaded and is not a corrupt image. If the network activity is interrupted onerror is fired. – Akhil Arjun Commented Jan 4, 2017 at 10:59
  • @AkhilArjun, Not looking for what, but how. – dovid Commented Jan 4, 2017 at 11:12
  • @lomed did u find a way? – Pradip Vaghasiya Commented Jan 5, 2017 at 10:42
  • @PradipVaghasiya yes. – dovid Commented Jan 5, 2017 at 14:38
  • Can you provide me with a full base64 data for this image, to test it out? I almost found the solution :) – rossanmol Commented Jan 7, 2017 at 16:23
 |  Show 7 more comments

3 Answers 3

Reset to default 8 +100

You can decode an image to an array of bytes:

var src = 'here comes your base64 data'
var imageData = Uint8Array.from(atob(src.replace('data:image/jpeg;base64,', '')), c => c.charCodeAt(0))

JPEGs must start with the bytes FF D8 and end with FF D9, so we check if last two elements of the created array buffer is 255 and 217. See live example.

var imageCorrupted = ((imageData[imageData.length - 1] === 217) && (imageData[imageData.length - 2] === 255));

We can use a similar check for PNGs (live example), which end with an IEND chunk containing this sequence of bytes:

// in hex: 00 00 00 00 49 45 4e 44 ae 42 60 82
var sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130];

you could check corrupted pixels by canvas like this code

var ctx = document.getElementById('canvas').getContext('2d');
var img = new Image();
img.onload = function(){
    ctx.drawImage(img,0,0);
    var height=this.height;
    var width=this.width;
    var hCenter=Math.round(width/2);
    var corruptedRowsCount=0;
    for(var row=height;row>0;row--){
      var c = ctx.getImageData(hCenter, row, 1, 1).data;
      if(c[0]==0 && c[1]==0 && c[2]==0 && c[3]==0)
          corruptedRowsCount++;
      else 
          break;
    }
    console.log(Math.round(corruptedRowsCount*100/height)+" precent of image is corrupted");
};

img.src="";
<canvas id="canvas">

For png files, I decided that I wanted a solution that did more than just check the first and last bytes of the file to see if they were valid. I wanted a solution that actually made use of the embedded crc codes for each chunk inside the png file to check all the data inside the file for corruption.

Luckily I found a mature library that does this: https://github.com/lukeapage/pngjs

Unfortunately it is rather large. Almost 500 kb for the browser version. It is a fully featured png file manipulation library, which makes this understandable. If you have a use case that needs all these features then you might be ok with paying for the size. But it is too heavy for the simple use case of just wanting to validate a png file.

So I cut out the validation code from it and made a simple little 2.5 kb npm package with just the validation code in it: https://www.npmjs.com/package/png-validator

发布评论

评论列表(0)

  1. 暂无评论