A simple Express app for proxying and manipulating images, specifically headshots.
The code is just over 100 lines, making it easy to tailor to your needs.
npm install
node index.js
curl -I http://localhost:5000/http%3A%2F%2Fwww.opennorth.ca%2Fimg%2Fheader_logo.png/352/72
The URL structure is /:url/:width/:height
. The :url
parameter must be escaped/encoded. If the remote image's width or height is greater than the given :width
or :height
, it will be resized, maintaining aspect ratio, and cropped. If smaller, it will be padded with white pixels. The equivalent ImageMagick command is:
convert in.jpg -thumbnail 100x100^> -gravity center -extent 100x100 out.jpg
The Cache-Control
header sets a max-age
of one year.
git clone https://github.com/opennorth/image-proxy.git
heroku create
heroku config:set NODE_ENV=production
git push heroku master
heroku apps:open
Create a distribution and set the "Origin Domain Name" to the domain name of your Heroku app.
Image proxy:
- Supports HTTP and HTTPS
- Follows 301 and 302 redirects
- Sets a maximum timeout for the remote server
- Handles complex MIME types like
image/jpeg; charset=utf-8
- Optional whitelisting using regular expressions
Image manipulation:
- Accepts a custom width and height, up to a maximum extent
- Resizes, centers and crops the image
HTTP server:
- No query string parameters (preferred by CloudFront)
- Adds a Cache-Control header
If you need more features, see node-imageable and node-imageable-server.
This project's main repository is on GitHub: http://github.com/opennorth/image-proxy, where your contributions, forks, bug reports, feature requests, and feedback are greatly welcomed.
This project is developed by Open North through a partnership with the Participatory Politics Foundation and is inspired by node-connect-image-proxy.
Copyright (c) 2013 Open North Inc., released under the MIT license