nginx custom error page 502 with css and image files
I just had the same problem, and what did work is setting the nginx conf like this :
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /home/username/sites/myProject/current/errorPages;
}
location = /image.png {
root /home/username/sites/myProject/current/errorPages/50x_files;
}
And then reference the image simply as src="image.png". The same should apply to your css and js!
Edit : I find a way to make it work for a bunch of file:
error_page 500 502 503 504 /errorPages/50x.html;
location /errorPages/ {
root /home/username/sites/myProject/current/;
}
This way all the files in the errorPages folder will be available (e.g. src="/errorPages/image.png"), as nginx will try to match all "/errorPages/...". It is necessary to remove both the "=" after "location" (as it's not an exact match anymore) and the "internal;" in it (as the other resources will be called from the html and not internally by nginx).
I think the best approach is to do the following things:
- Use
inline CSS
- Convert your images to
Base64
After doing this, you can embed the generated Base64 string into the background-image
CSS rule as follows:
background-image: url(.....==)
You can use the string with the <img>
tags as well, just pass it to the src
attribute as follows:
<img src=".....==" />
This way you can keep the internal
nginx rule.
The reason that your image/css is not shown/loaded, is because you're using the internal
directive. The internal
directive specifies that a given location can only be used for internal requests, and is not available or accessible from the outside (i.e. http://mysite/errorPages/500.html). Thus, a 404 error on its turn is given for these files.
A few workarounds are:
Remove the internal directive
error_page 500 502 503 504 /50x.html; location = /50x.html { root /home/username/sites/myProject/current/errorPages; }
- Use
css inline styles
for your error pages. This however won't work for your images, or other files that are linked to your page. - Place the css and image files outside of the errorPages folder, and refer to them in your html code, with a relative path, starting from the root of your website.
This worked for me:
error_page 500 502 503 504 = @errorz;
location @errorz{
root /home/username/sites/myProject/current/errorPages;
try_files $uri /50x.html = 502 503;
}