admin 发表于 2016-12-10 11:07:22

nginx配置HTTPS

使用ssl模块配置同时支持http和https并存一,生成证书# 1、首先,进入你想创建证书和私钥的目录,例如:
cd /etc/nginx/

# 2、创建服务器私钥,命令会让你输入一个口令:
openssl genrsa -des3 -out server.key 1024

# 3、创建签名请求的证书(CSR):
openssl req -new -key server.key -out server.csr

# 4、在加载SSL支持的Nginx并使用上述私钥时除去必须的口令:
cp server.key server.key.org
openssl rsa -in server.key.org -out server.key


# 5、最后标记证书使用上述私钥和CSR:
openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

二,配置nginx

cd /etc/nginx
vim nginx.conf
#
# HTTPS server configuration
#
server {
<b>    listen       443;</b>
    server_name本机的IP地址;

<b>    ssl                  on;
    ssl_certificate      /etc/nginx/server.crt;
    ssl_certificate_key/etc/nginx/server.key;

    ssl_session_timeout5m;</b>

#    ssl_protocolsSSLv2 SSLv3 TLSv1;
#    ssl_ciphersALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
#    ssl_prefer_server_ciphers   on;

    location / {
      #root   html;
      #indextestssl.html index.html index.htm;
   proxy_redirect 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_pass http://IP地址/ssl/;
    }
}重启nginx,在浏览器输入:https://IP地址 会跳转到 http://IP地址/ssl/ 这个地址(后期调整为webservice接口地址即可)


三、将http访问 重定向到 https (解决方法:nginx rewrite 加上 location 方式实现)
location ~ / {
      if ($server_port ~ "^80$"){
            set $rule_0 1$rule_0;
      }
      if ($rule_0 = "1"){
            rewrite /(.*) https://IP地址/$1 permanent;                     break;
      }
    }



页: [1]
查看完整版本: nginx配置HTTPS