NginX отбрасывает данные сеанса, выступая в качестве обратного прокси-сервера SSL для приложения sinatra

Я в значительной степени застрял в этой точке. У меня есть веб-сайт, обслуживаемый на Mizuno (вариант с Jetty, я думаю), использующий Padrino (вариант sinatra), через порт 8080, с прослушиванием Nginx на 80/443, чтобы разрешить SSL-прокси к нему.

На сайте есть стена входа в систему, где пользователь входит в систему, а затем оспаривается, прежде чем ему будет разрешен доступ к сайту. Всякий раз, когда я обращаюсь к нему через порт 8080 напрямую, все работает как положено, однако, когда я прохожу через Nginx, я могу только попасть на страницу с запросом. Это вынуждает меня вернуться на страницу входа в систему всякий раз, когда я пытаюсь опубликовать свой ответ на вызов.

РЕДАКТИРОВАТЬ: Кроме того, когда я вхожу в систему, приложение на самом деле правильно войти в систему меня. Если я пытаюсь получить доступ к следующей странице напрямую через порт 8080, после того, как меня выгнали через nginx, он разрешает доступ.

Мой конфиг nginx как ниже

server {
    listen 443;
    server_name secure.website.io;
    ssl_certificate ssl-bundle.crt;
    ssl_certificate_key website.key;
    ssl on;
    ssl_session_timeout 5m;
    ssl_protocols SSLv3 TLSv1;
    ssl_ciphers ALL:!aNULL:!ADH:!eNULL:!LOW:!EXP:RC4+RSA:+HIGH:+MEDIUM;
    ssl_prefer_server_ciphers on;
    location / {
            proxy_redirect  off;
            proxy_set_header Host $http_host;
            proxy_set_header        X-Real-IP       $remote_addr;
            proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header   X-NginX-Proxy  true;
            client_max_body_size   10m;
            client_body_buffer_size        128k;
            proxy_connect_timeout  90;
            proxy_send_timeout     90;
            proxy_read_timeout     90;
            proxy_buffer_size      4k;
            proxy_buffers  4 32k;
            proxy_busy_buffers_size        64k;
            proxy_temp_file_write_size     64k;
            proxy_pass      http://127.0.0.1:8080;
    }
}
server {
    listen  80;
    server_name     secure.website.io;
    rewrite ^       https://$server_name$request_uri? permanent;
}

Я что-то здесь упускаю?

1 ответ

Я нашел обходной путь для этого. Отменив Mizuno для Phusion Passenger, я смог полностью удалить nginx из микса и использовать SSL-сертификат, используя параметры конфигурации Passenger.

Другие вопросы по тегам