Redirect и url_for во Flask дважды добавляют домен на prod-сервер через Gunicorn и Nginx - PullRequest
0 голосов
/ 04 июня 2018

У меня проблемы с перенаправлением во Flask на prod сервере.Примечание: это не происходит локально, только при работе на Prod-сервере с Nginx и Gunicorn.Проблема началась, когда https и домен был добавлен.Я не уверен, что проблема в флешке или моих настройках nginx.

Моя проблема возникает для всех перенаправлений, но вот пример: return redirect(url_for('.login')).Ожидаемый результат здесь - «domain.com/login», но он перенаправляет на «domain.com% 2Cdomain.com / login».Когда я печатаю `url_for ('. Login'), он показывает" / login ".

При поиске решений я обнаружил, что это может быть что-то с моими настройками nginx, поэтому вот они:

server {
    server_name domain.com www.domain.com;

    #Fix for socket.io, dont think this is related
    location /socket.io {
            proxy_pass http://127.0.0.1:8088/socket.io;
            proxy_redirect off;
            proxy_buffering off;
            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_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "Upgrade";
}

    location / {
            include proxy_params;
            proxy_pass http://127.0.0.1:8088;
    }

listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/domain.com/fullchain.pem; # managed by 
Certbot
ssl_certificate_key /etc/letsencrypt/live/domain.com/privkey.pem; # managed 
by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot


}
server {
if ($host = www.domain.com) {
    return 301 https://$host$request_uri;
} # managed by Certbot


if ($host = domain.com) {
    return 301 https://$host$request_uri;
} # managed by Certbot


    listen 80;
    server_name domain.com www.domain.com;
return 404; # managed by Certbot
}

Обратите внимание, что я заменил наш домен на "domain.com".

Если есть какая-либо дополнительная информация, которую я могу предоставить, пожалуйста, дайте мне знать.

Редактировать: Решено.Мне пришлось удалить строку include proxy_params; в моем конфигурационном файле nginx.Я не знаю почему, но это сработало.Теперь поведение такое, как и ожидалось.Я пытаюсь пометить этот пост как решенный, но в нем говорится, что мне нужно подождать несколько дней.

1 Ответ

0 голосов
/ 04 июня 2018

Хорошо, я понял это.Мне пришлось удалить строку include proxy_params; в моем конфигурационном файле nginx.Не знаю почему, но потом все заработало как положено.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...