Ghost doesn't load images
Problem
Ghost is fantastic, as soon as I met it I was a fan of it, even more because it's open source, but one of my first difficulties was loading images when using https.
data:image/s3,"s3://crabby-images/ed954/ed954a4f41cc2335bc0d4d0f2fd0a041fc446383" alt=""
Main cause
Investigating I discovered that this happens when using https but the images are loaded in http.
data:image/s3,"s3://crabby-images/e9230/e9230001da61dd4bb2750258f6f1973f60227bfa" alt=""
Solution
To resolve this issue, some adjustments had to be made. The first one is to change the container parameter url
from http
to https
:
docker run -d --name ghost --hostname ghost -v /iop/data/ghost:/var/lib/ghost/content -e url=https://lucaspolloni.xyz -p 3001:2368 ghost
It will be necessary to review the apache settings, first of all activate the module headers
:
a2enmod headers
Then add the request header X-Forwarded-Proto
in the apache vhost:
<IfModule mod_ssl.c>
<VirtualHost *:443>
...
RequestHeader set "X-Forwarded-Proto" expr=%{REQUEST_SCHEME}
...
</VirtualHost>
</IfModule>
/etc/apache2/sites-available/lucaspolloni-le-ssl.conf
Restart apache service:
systemctl restart apache2
Now it's time to test:
data:image/s3,"s3://crabby-images/730d0/730d0aa26cd35fee960558c72726af75c37c1803" alt=""