I'm trying to add a custom error page for 503. I added these lines to server conf in nginx.conf file:
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /home/username/sites/myProject/current/errorPages;
internal;
}
It displays the custom page when uwsgi is down, however this doesn't show any images. I tried many different configurations I can think of, but no luck. How I can display image file and enable css for a custom error page?
I put my custom error page into /home/username/sites/myProject/current/errorPages
and the file structure is:
errorPages/50x.html
errorPages/50x_files/50x.css
errorPages/50x_files/50x.js
errorPages/50x_files/image.png
The default error response from NGINX is in an HTML format. It looks like this. The 502 error is received if the upstream service is down. It’s not pretty right? Imagine showing this error page to your customers. To show your custom error page when NGINX got errors you see this sample config file.
The page that will be returned is an HTML file errors502.html in directory /var/html. We define that error page for code 502 by using error_page 502 @html502error; on line 8. The location of @html502error is defined on lines 11 to 14, where we define the root directory and the file location.
Thx! You don't create a new server block. Just include the maintenance.default file into the existing server block (s) for the affected domain (s). Nginx serves the 503.html file all by itself so the java app is not, and should not be, called at all.
Nginx serves the 503.html file all by itself so the java app is not, and should not be, called at all. BTW, all your regular server block elements stay intact and you just include the maintenance.default file which takes over the process. When you remove the "include" line, you return to the normal setup.
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).
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;
}
css inline styles
for your error pages. This however won't work for your images, or other files that are linked to your page.I think the best approach is to do the following things:
inline CSS
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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With