Basic call
To initiate a standard call and receive a JSON response, simply call this URL and specify the image like one of the following options:
GET
– Parameterimg
POST
– Parameterimg
FILES
– Binary sentfiles
The webservice will return an array containing details about the compressed image, as described below.
API output
reSmush.it can return responses in:
- JSON (XML is deprecated)
The output array contains various information, such as:
- The source URL (when using the
GET
orPOST
method) (parametersrc
) - The URL of the optimized image (parameter
dest
) - The original file size (parameter
src_size
) - The optimized file size (parameter
dest_size
) - The percentage of improvement (parameter
percent
) - The date on which the file is to be deleted from the server (parameter
expires
) - The error code (parameter
error
) - The error description (parameter
error_log
)
Compression
Since July 2015 (v.1.4.2) you can now specify the optimization level for JPG compression. To do this, simply add the following parameter in the GET
method:
qlty
, with a value between 0 and 100. The default value is 92. To get a good image quality, the value should be above 90.
Example of use:
curl \
-H "User-Agent: MyCustomUserAgent/1.0" \
-H "Referer: https://example.com" \
"https://api.resmush.it/ws.php?img=https://resmush.it/wp-content/uploads/2024/02/testimage.jpg&qlty=95"
Please note that including the user-agent and website address in your API request is mandatory for security reasons.
EXIF data
Since February 2017 (v.1.4.21), the EXIF data is removed by default to reduce the file size. However, this data can be retained during compression by specifying the following parameter in the GET
method:
exif
with the valuetrue
. The default value isfalse
.
API Errors
Here is the list of the various errors of the web service:
- 301 – Old endpoint used. Consider using
api.resmush.it
instead. - 400 – No image URL provided.
- 401 – The image cannot be fetched from the URL (usually a local URL).
- 402 – The image cannot be fetched from
$_FILES
(usually a local URL). - 403 – Forbidden file format specified. Only works with JPG, PNG, GIF, TIF and BMP files.
- 404 – Unknown method or resource requested.
- 501 – Internal error, cannot create a local copy.
- 502 – Provided image too large (must be less than 5 MB).
- 503 – Internal error, reSmush.it server for image optimization could not be reached.
- 504 – Internal error, the image could not be retrieved from the reSmush.it servers.
Compatibility
reSmush.it is 100% compatible with the old, non-functioning Yahoo Smush.it webservice.
You just need to replace the old API call http://www.smushit.com/ysmush.it/ws.php?img=
with the reSmush.it webservice URL, which works exactly like ?img=
.
reSmush.it has been verified to work perfectly with the Drupal module ImageAPI Optimize (dev version) and the official WordPress reSmush.it Image Optimizer plugin.
Examples of implementation (PHP)
#1 Simple PHP request (using GET and with a JSON response)
<?php
define('WEBSERVICE', 'http://api.resmush.it/ws.php?img=');
$s = 'http://www.mywebsite/image.jpg';
// Create a stream context to include custom headers
$context = stream_context_create([
'http' => [
'method' => 'GET',
'header' => "User-Agent: MyCustomUserAgent/1.0\r\n" .
"Referer: https://example.com\r\n"
]
]);
// Fetch data with the custom headers
$o = json_decode(file_get_contents(WEBSERVICE . $s, false, $context));
if (isset($o->error)) {
die('Error: ' . $o->error);
}
// Output the URL of the optimized picture
echo $o->dest;
#2 PHP Request (sending file directly to the API). Recommended method!
<?php
$file = '/path/to/myfile.jpg';
$mime = mime_content_type($file);
$info = pathinfo($file);
$name = $info['basename'];
$output = new CURLFile($file, $mime, $name);
$data = array(
"files" => $output,
);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'http://api.resmush.it/?qlty=80');
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
curl_setopt($ch, CURLOPT_USERAGENT, 'MyCustomUserAgent/1.0');
curl_setopt($ch, CURLOPT_REFERER, 'https://example.com');
$result = curl_exec($ch);
if (curl_errno($ch)) {
$result = curl_error($ch);
}
curl_close($ch);
var_dump($result);
Please note that including the user-agent and website address in your API request is mandatory for security reasons.
Connection issues?
If you encounter any kind of connection issues or errors, please whitelist our IPs below and try again:
46.4.70.115
176.9.77.187
136.243.103.55
213.239.204.84
144.76.74.20
65.109.126.11
135.181.240.104
For a more advanced image optimization API including generate WebP and generate AVIF, consider exploring the ShortPixel API.