Django如何仅将example.com重定向到https并将* .example.com重定向到http?

时间:2018-07-01 11:07:00

标签: django ubuntu

我需要http://example.com重定向到https://example.comhttp://www.example.comhttp://api.example.com不能重定向,即子域不必重定向到https。

我可以通过查看它来了解配置。但是不知道要进一步发展。请帮我。 到目前为止,我的配置是:

网站可用/default.py

upstream app_server {
server unix:/home/django/gunicorn.socket fail_timeout=0;
}

server {
server_name example.com www.example.com cloud.example.com api.example.com; 
listen 80;
return 301 https://example.com$request_uri;
}

server {
server_name example.com www.example.com cloud.example.com api.example.com;

listen 443;  # <-

ssl on;  # <-
ssl_certificate /etc/ssl/example_cert_chain.crt;  # <-
ssl_certificate_key /etc/ssl/example.key;  # <-
#listen 80 default_server;
#listen [::]:80 default_server ipv6only=on;

root /usr/share/nginx/html;
index index.html index.htm;

client_max_body_size 4G;
server_name _;

keepalive_timeout 5;

# Your Django project's media files - amend as required
location /media  {
    alias /home/django/django_project/media;
}

# your Django project's static files - amend as required
location /static {
    alias /home/django/django_project/static/;
}

# Proxy the static assests for the Django Admin panel
location /static/admin {
   alias /usr/lib/python2.7/dist-packages/django/contrib/admin/static/admin/;
}

location / {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto https;  # <-
proxy_set_header X-Forwarded-Protocol $scheme;
        proxy_set_header Host $http_host;
        proxy_redirect off;
        proxy_buffering off;

        proxy_pass http://app_server;
}

}

1 个答案:

答案 0 :(得分:2)

编辑此内容

server { 
    server_name example.com www.example.com cloud.example.com api.example.com;
    listen 80; 
    return 301 https://example.com$request_uri; 
}

进入:

server { 
    server_name example.com www.example.com cloud.example.com api.example.com;
    listen 80; 
    if ($http_host = "example.com") { 
        rewrite ^ https://example.com$request_uri permanent;
    }
}