ПРОЕКТЫ 


  АРХИВ 


Apache-Talk @lexa.ru 

Inet-Admins @info.east.ru 

Filmscanners @halftone.co.uk 

Security-alerts @yandex-team.ru 

nginx-ru @sysoev.ru 


  СТАТЬИ 


  ПЕРСОНАЛЬНОЕ 


  ПРОГРАММЫ 



ПИШИТЕ
ПИСЬМА












     АРХИВ :: nginx-ru
Nginx-ru mailing list archive (nginx-ru@sysoev.ru)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

поведение ssl on/off в разных se rver{}


  • To: nginx-ru@xxxxxxxxx
  • Subject: поведение ssl on/off в разных se rver{}
  • From: umask <umask@xxxxxxxxx>
  • Date: Wed, 23 Mar 2011 10:58:36 +0300
  • Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yandex.ru; s=mail; t=1300867117; bh=BWp83Yg+oYIBDUX7z5J5gL8eFdHfKH9gv1H1Yi0dVWQ=; h=From:To:Subject:MIME-Version:Message-Id:Date: Content-Transfer-Encoding:Content-Type; b=qDmumLsntC4rNeOiPg92aoeQb5WhJXUODTfacB86puioS0WEl341T5CN0EsYQvBQ2 T2ZVblcKYQ5v+mkczI6soWRZd5LTi6K9jZ4Ftul1cVAewBUgeJJF3GR0qKfnoKjtQI EizzQcD8CweoDDADslhTp6MuB/42An2H6axd/N6w=

Добрый день,

натолкнулся на проблему с SSL и никак не могу понять от чего это происходит.

Есть вот такая конфигурация 

====================8<=======================
http {
        server {
                listen 80 default;
                listen 443 ssl default;
                server_name _;

                ssl                  off;
                ssl_certificate      example.pem;
                ssl_certificate_key  example.key;

                location / {
                        rewrite . http://example.ru/ redirect;
                        break;
                }
        }

        server {
                listen       80;
                listen       443 ssl;
                server_name  example.ru;
                ssl                  on;
                ssl_certificate      example.pem;
                ssl_certificate_key  example.key;
                location / {
                        return 500;
                }
        }
}
====================8<=======================

которая успешно работает и выполняет свою цель - если кто-то пришёл на наш IP 
(не по host'у) или прописал на какое-то левое DNS-имя наш IP-адрес, то nginx 
должен редиректить на домен example.ru. Причём не важно пришли ли к нам по HTTP 
или HTTPS (да, будет проблема с невалидным сертификатом, но пока для нас этот 
момент незначим).




В свою очередь конфигурация (ssl on в первом server{}):

====================8<=======================
http {
        server {
                listen 80 default;
                listen 443 ssl default;
                server_name _;

                ssl                  on; # 
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
                ssl_certificate      example.pem;
                ssl_certificate_key  example.key;

                location / {
                        rewrite . http://example.ru/ redirect;
                        break;
                }
        }

        server {
                listen       80;
                listen       443 ssl;
                server_name  example.ru;
                ssl                  on;
                ssl_certificate      example.pem;
                ssl_certificate_key  example.key;
                location / {
                        return 500;
                }
        }
}
====================8<=======================

Перестаёт работать ожидаемым образом и происходит следующее (при запросе 
http://pupkin.ru/, pupkin.ru прописан в hosts):
2011/03/23 07:56:53 [info] 90517#0: *15 client sent plain HTTP request to HTTPS 
port while reading client request headers, client: 10.0.32.11, server: _, 
request: "GET / HTTP/1.1", host: "pupkin.ru"




_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://nginx.org/mailman/listinfo/nginx-ru


 




Copyright © Lexa Software, 1996-2009.