My question is similar to this one, except that I have another nginx server behind the frontend nginx ssl proxy server:
-------------------------- -------------------------------- ----------
| nginx: https://bla.com | -----> | nginx: http://localhost:8080 | ----> | Joomla |
-------------------------- -------------------------------- ----------
Is there a similar option to SetEnvIfNoCase X-Forwarded-Proto https HTTPS=on
in nginx?
Currently I have the problem, that static content such as javascript and css files are not served.
Configuration on frontend nginx proxy:
server {
listen 443;
listen [::]:443 ipv6only=on;
server_name bla.com;
// cut ssl settings
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# Fix the “It appears that your reverse proxy set up is broken" error.
proxy_pass http://localhost:8080;
proxy_read_timeout 90;
proxy_redirect http://localhost:8080 https://bla.com;
}
}
server {
listen 80;
listen [::]:80 ipv6only=on;
server_name bla.com www.bla.com;
return 301 https://bla.com$request_uri;
}
As I understand it, I need to evaluate the "X-Forwarded-Proto" header in the "inner" nginx configuration and set HTTPS
environment variable, so joomla can react accordingly (library/joomla/uri/uri.php
):
// Determine if the request was over SSL (HTTPS).
if (isset($_SERVER['HTTPS']) && !empty($_SERVER['HTTPS']) && (strtolower($_SERVER['HTTPS']) != 'off'))
{
$https = 's://';
}
else
{
$https = '://';
}
I just don't know how :)