Nginx:支持 HTTPS

文章目录

    • [Nginx 开启 ssl 以支持 HTTPS](#Nginx 开启 ssl 以支持 HTTPS)
      • [1 生成本地证书](#1 生成本地证书)
      • [2 开启 ssl 以支持 HTTPS](#2 开启 ssl 以支持 HTTPS)
      • [3 将 https 的请求转发给 http](#3 将 https 的请求转发给 http)
    • [最终的 nginx.conf 如下](#最终的 nginx.conf 如下)

Nginx 开启 ssl 以支持 HTTPS

!IMPORTANT

在下文中,将采用如下定义。

HTTP端口: 80

HTTPS端口: 443

服务地址: www.0ll1.com,也可以是 IP

1 生成本地证书

  1. 生成一个 RSA 私钥:server.key

    nginx 复制代码
    openssl genrsa -out server.key 2048
  2. 生成一个自签名的 X.509 证书:server.crt

    nginx 复制代码
    openssl req -new -x509 -days 8760 -key server.key -out server.crt -subj "/C=CN/O=Institute of Information Engineering, CAS/CN=www.0ll1.com"

2 开启 ssl 以支持 HTTPS

nginx 复制代码
server {
    listen 443 ssl;
    server_name www.0ll1.com;
    ssl_certificate /usr/local/nginx/cert/server.crt;
    ssl_certificate_key /usr/local/nginx/cert/server.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH;
    ssl_prefer_server_ciphers on;
}

3 将 https 的请求转发给 http

nginx 复制代码
server {
    location / {
        proxy_set_header Host $host;
        proxy_redirect off;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_connect_timeout 60;
        proxy_read_timeout 600;
        proxy_send_timeout 600;
        proxy_pass http://www.0ll1.com:80;
    }
}

!NOTE

只需要将 proxy_pass 修改为 http 服务的 url 即可。

最终的 nginx.conf 如下

nginx 复制代码
server {
    listen 443 ssl;
    server_name www.0ll1.com;
    ssl_certificate /usr/local/nginx/cert/server.crt;
    ssl_certificate_key /usr/local/nginx/cert/server.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH;
    ssl_prefer_server_ciphers on;

    location / {
        proxy_set_header Host $host;
        proxy_redirect off;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_connect_timeout 60;
        proxy_read_timeout 600;
        proxy_send_timeout 600;
        proxy_pass http://www.0ll1.com:80;
    }
}
相关推荐
杜子不疼.17 分钟前
《Python学习之文件操作:从入门到精通》
数据库·python·学习
TDengine (老段)40 分钟前
TDengine IDMP 高级功能(4. 元素引用)
大数据·数据库·人工智能·物联网·数据分析·时序数据库·tdengine
DashVector1 小时前
如何通过Java SDK分组检索Doc
java·数据库·面试
Olrookie2 小时前
XXL-JOB GLUE模式动态数据源实践:Spring AOP + MyBatis 解耦多库查询
java·数据库·spring boot
苏婳6662 小时前
【最新版】怎么下载mysqlclient并成功安装?
数据库·python·mysql
芥子沫2 小时前
Jenkins常见问题及解决方法
windows·https·jenkins
Tapdata3 小时前
《实时分析市场报告 2025》上线 | 从批处理到实时洞察,2025 年全球实时分析市场全景解读
数据库
海梨花4 小时前
【从零开始学习Redis】项目实战-黑马点评D2
java·数据库·redis·后端·缓存
timeweaver4 小时前
深度解析 Nginx 前端 location 配置与优先级:你真的用对了吗?
前端·nginx·前端工程化
代码的余温5 小时前
SQL性能优化全攻略
数据库·mysql·性能优化