How to serve WebP images with a Drupal 8/Drupal 9 site
Requirements
PHP
Your web server needs to support WebP through PHP.
PHP 5 >= 5.4.0
GD Library
Check your PHP setup
How to check if everything is working as expected:
php -i | grep 'WebP'
If everything is working fine you should see
WebP Support => enabled
We should be ready to go on, yay 🎉
If you get another output, you might need to enable/install libgd and enable it in your PHP.ini.
Drupal
This tutorial only works with Drupal 8/9. As a start you’ll need to enable/install some modules:
- ImageAPI Optimize
https://www.drupal.org/project/imageapi_optimize
The module has built in support for core Image styles and a service allowing use in third party modules. - ImageAPI Optimize WebP
https://www.drupal.org/project/imageapi_optimize_webp
⚠️ Make sure to enable the “ImageAPI Optimize WebP Responsive” submodule if you’re using the Responsive Image module in Drupal Core. - ImageAPI Optimize Binaries
https://www.drupal.org/project/imageapi_optimize_binaries
This module is optional but it provides support for popular binary image processors like JpegOptim, PngQuant, AdvPNG etc.
data:image/s3,"s3://crabby-images/3cb92/3cb920032150b0ef0642e503b6f104316f94cfe7" alt=""
Drupal Configuration
Head over to /admin/config/media/imageapi-optimize-pipelines for the Image API configuration.
data:image/s3,"s3://crabby-images/4294a/4294a2e16094fa57ce1ff12895638af242181171" alt=""
Let’s create a new pipeline
1. Add a new optimization pipeline
By clicking on “+ Add optimization pipeline”
data:image/s3,"s3://crabby-images/4294a/4294a2e16094fa57ce1ff12895638af242181171" alt=""
2. Name your pipeline
I will call the pipeline “optimize images” but you can name it whatever you would like.
data:image/s3,"s3://crabby-images/8ab93/8ab930b27ba87c616d3919b45a29b82ca331b0bc" alt=""
3. Choose your processor
We choose “WebP Deriver”.
data:image/s3,"s3://crabby-images/bd345/bd345566cf0637614f5cae259ec6e9bcc1353ff8" alt=""
You should place the WebP processor before any other compression processors to avoid multiple compression of an image. This can have an inverse affect and provide a lower quality image at a larger file size.
4. Set image quality
You can set the image quality here, 80–90% should serve with good overall quality. 100% will be lossless.
data:image/s3,"s3://crabby-images/41c4e/41c4e1c28197e1c09f4dbc29c25343ac2d33549b" alt=""
5. Save
Click on “Save configuration” and you’re done.
⚠️ Don’t forget to clear the Drupal cache after this.
Enjoy WebP images with your Drupal site!