nginx配置https證書


一、本地生成證書

1、首先,進入你想創建證書和私鑰的目錄,例如:
  cd /usr/local/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

這樣,當前目錄下就生成四個文件:
  server.crt
  server.csr
  server.key
  server.key.org

6、配置nginx.conf

#
# HTTPS server configuration
#
server {
listen 443;
server_name 本機的IP地址;

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

ssl_session_timeout 5m;

# ssl_protocols SSLv2 SSLv3 TLSv1;
# ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
# ssl_prefer_server_ciphers on;

location / {
#root html;
#index testssl.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 目標地址;
}
}


二、外部獲取域名的綁定https證書
1、下載nginx版本的證書
2、將xxx.pem文件和xxx.key文件放入想要存放的目錄,比如:
  cd /usr/local/nginx/cert/

3、配置nginx.conf
server {
  listen 443 ssl;
  server_name 域名;
  ssl on;
  ssl_certificate "/usr/local/nginx/cert/xxxxx.pem";
  ssl_certificate_key "/usr/local/nginx/cert/xxxxx.key";

  ssl_session_cache shared:SSL:1m;
  ssl_session_timeout 10m;

  ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!aNULL:!MD5:!ADH:!RC4;
  ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
  ssl_prefer_server_ciphers on;

  location / {
    proxy_pass 目標地址;
  }
}
4、如果想要http訪問自動轉發到https需要在nginx.conf文件中添加
server {
  listen 10003;
  server_name http://IP;
  rewrite ^(.*)$ https://$host$1 permanent;

  #charset koi8-r;

  #access_log logs/host.access.log main;

  location / {
    proxy_pass https://IP:PORT;
  }
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM