/node-image-size-scanner

Report the image file sizes for a given URL

Primary LanguageJavaScript

Build Status Dependencies

node-image-size-scanner

For a given URL, report image file sizes and paths sorted by decreasing size. Optionally specify byte threshold value to report on. Formatted output or json output. Follows redirects. Reports missing or unreachable images

Installation

npm install -g node-image-size-scanner

Usage

Command Line

$ image_check
Usage: image_check -u URL [-b MIN_BYTES_TO_ALERT_ON] [-j|-json] [-i|-ignore-errors]
Ex: image_check -u http://www.google.com -b 1k

Formatted Output

$ image_check -u http://ww2.kqed.org/news/ -b 1000K
Image files >1000 KB (1024000 bytes)
    3.64 MB http://i1.wp.com/ww2.kqed.org/news/wp-content/uploads/sites/10/2016/02/IMG_0057.jpg?resize=1920%2C1440
    2.74 MB http://u.s.kqed.net/2016/02/16/SchmitzSJSUstatue1920.jpg
    2.55 MB http://i2.wp.com/ww2.kqed.org/news/wp-content/uploads/sites/10/2016/02/dirt_CPUC-2.jpg?resize=1920%2C1282
    1.31 MB http://u.s.kqed.net/2016/02/15/GettyImages510369410Syriaattackfeb15.jpg

JSON output

$ image_check -u https://www.google.com -b 1k -j | json
{
  "url": "https://www.google.com",
  "byte_threshold": 1024,
  "images": [
    {
      "url": "https://www.google.com/images/srpr/logo9w.png",
      "bytes": 8228
    },
    {
      "url": "https://www.google.com/images/icons/product/chrome-48.png",
      "bytes": 1834
    }
  ]
}

Module

See the examples directory.

params

  • byte_threshold: Integer. The number of bytes that an image has to exceed in order to be reported
  • ignore_image_errors: Boolean. Do not report images that cannot be sized. (404s, etc)

Promises Example

var NodeImageSizeScanner = require('../index');

var options = {
    log_level : 'err' // err, info, debug, off
};

var scanner = new NodeImageSizeScanner(options);

var runtime_options = {
    url             : 'http://www.nyt.com',
    byte_threshold  : '5k',
};

scanner.check(runtime_options)
.then(function(json){
    console.log(json);
}).
catch(function(err){
    console.error(err);
});

Async Example

var NodeImageSizeScanner = require('../index');

var options = {
    log_level : 'err' // err, info, debug, off
};

var scanner = new NodeImageSizeScanner(options);

var runtime_options = {
    url             : 'http://www.nyt.com',
    byte_threshold  : '5k',
};

scanner.checkAsync(runtime_options, function(err, json){
    if (err) {
        return console.error(err);
    }
    console.log(json);
});

Tests

npm test

Release Notes

1.0.7

  • added ignore_image_errors param to skip reporting of images that can't be sized

1.0.3

  • 1k now converts to 1024 bytes

1.0.2

  • json output is now url instead of redundant image_url

1.0.0

  • Converted to being a true module using Promises
  • Added support for reporting 404 errors for missing images
  • Added examples
  • Added unit tests

0.1.0

  • Switched to request module to gain redirect following