Nginx HTTP未重定向到HTTPS 400错误请求“普通HTTP请求已发送到HTTPS端口”

时间:2019-03-06 16:13:44

标签: docker nginx nginx-reverse-proxy nginx-config

我正在docker中运行nginx。 HTTPS可以正常工作,但是当我明确发出HTTP请求时,出现以下错误

400错误的请求 普通的HTTP请求已发送到HTTPS端口

nginx.conf如下

worker_processes auto ;          
events {}

http {

include /etc/nginx/mime.types;

access_log /var/log/nginx/main.access.log;                                           

server {    
listen 80;                                                                                                       
location / {
    return 301 https://localhost:3000$request_uri; 
}

}

server {   
listen 443 ssl;                                                      
server_name  localhost:3000;                  
 root    /var/www/html; 

ssl_certificate         /etc/nginx/ssl/cert.pem; 
ssl_certificate_key     /etc/nginx/ssl/key.pem;

ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
ssl_ciphers ECDH+AESGCM:ECDH+AES256:ECDH+AES128:DH+3DES:!ADH:!AECDH:!MD5;

location / {
try_files  $uri /index.html;        
}

}

}

我使用

运行此容器
docker run -p 3000:443 -it -d --name nginxtest nginx-test

并出现以下错误

docker文件如下

FROM nginx:latest
COPY ./build /var/www/html
COPY ./nginx.conf /etc/nginx/nginx.conf
COPY ./ssl /etc/nginx/ssl
EXPOSE 443
CMD [ "nginx","-g","daemon off;" ]

奇怪的是,有时它可以很好地工作,突然间,如果我重新创建容器,它会停止工作,甚至无法工作。

甚至尝试执行以下操作。还是没有运气

 server {    
    listen 80;                                                                                                       
     server_name localhost:3000
        return 301 https://localhost:3000$request_uri; 
    }

当我运行以下docker命令时另一个奇怪的事情

docker run -p 3000:443 -p 3001:80 -it -d --name nginxtest nginx-test

并转到localhost:3001,它将我重定向到https很好,但是其他事情确实中断了。 很抱歉这个问题

1 个答案:

答案 0 :(得分:4)

将以下指令放入您侦听端口443的服务器块中。

error_page 497 https://$host:$server_port$request_uri;

此伪指令表示发生“纯HTTP请求已发送到HTTPS端口”时,将其重定向到当前主机名,端口和URI的https版本。

Kinda hacky但可以。