当前位置:   article > 正文

SSL原理、生成SSL密钥对、Nginx配置SSL

SSL原理、生成SSL密钥对、Nginx配置SSL

SSL原理:

SSL(Secure Sockets Layer)是一种加密通信协议,用于保护网络通信的安全性和隐私性。它的工作原理如下:

  1. 握手阶段:当客户端连接到服务器时,它向服务器发送一个“ClientHello”消息,其中包含支持的加密算法和随机数。服务器接收到消息后,回复一个“ServerHello”消息,其中包含服务器选择的加密算法和另一个随机数。
  2. 密钥交换阶段:服务器将自己的公钥(通常包含在服务器的数字证书中)发送给客户端。客户端验证证书的合法性,并生成一个随机的对称密钥(称为会话密钥)。客户端使用服务器的公钥加密这个会话密钥,并发送给服务器。
  3. 加密通信:客户端和服务器都拥有了相同的会话密钥,它们使用这个密钥来加密和解密通信数据,使数据在传输过程中保持机密性。
  4. 终止连接:当通信结束时,客户端和服务器可以终止SSL连接。

生成SSL密钥对:

  1. 生成私钥:

    openssl genpkey -algorithm RSA -out private-key.pem
  2. 生成自签名的公钥证书:

    openssl req -new -x509 -key private-key.pem -out public-cert.pem

Nginx配置SSL:

要在Nginx上配置SSL,首先确保你已经获得了SSL证书和私钥文件。然后,按照以下步骤进行配置:

  1. 在Nginx配置文件中找到需要启用SSL的虚拟主机块,通常是位于 /etc/nginx/conf.d/或 /etc/nginx/sites-available/目录下。
  2. 在虚拟主机块中添加以下配置来启用SSL并指定证书和密钥文件的路径:

    1. server {
    2. listen 443 ssl;
    3. server_name your_domain.com;
    4. ssl_certificate /path/to/public-cert.pem;
    5. ssl_certificate_key /path/to/private-key.pem;
    6. # 其他SSL相关配置
    7. }

    请将 your_domain.com替换为你的域名,/path/to/public-cert.pem和 /path/to/private-key.pem替换为证书和私钥文件的实际路径。

  3. 添加其他SSL相关配置,如SSL协议和密码套件的设置。以下是一个示例配置:

    1. ssl_protocols TLSv1.2 TLSv1.3;
    2. ssl_ciphers 'TLS_AES_128_GCM_SHA256:TLS_AES_256_GCM_SHA384:TLS_CHACHA20_POLY1305_SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384';
    3. ssl_prefer_server_ciphers off;
    4. ssl_session_cache shared:SSL:10m;
    5. ssl_session_timeout 10m;
    6. ssl_ecdh_curve secp384r1;
    7. ssl_session_tickets off;
    8. ssl_stapling on;
    9. ssl_stapling_verify on;
    10. resolver 8.8.8.8 8.8.4.4 valid=300s;
    11. resolver_timeout 5s;
  4. 保存配置文件并重新加载Nginx以使更改生效:

    1. sudo nginx -t # 检查配置文件语法是否正确
    2. sudo systemctl reload nginx # 重新加载Nginx配置

现在,你的Nginx虚拟主机应该已经配置了SSL,可以通过HTTPS安全访问。确保在生产环境中使用有效的SSL证书来保护通信的安全性

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/58639
推荐阅读
相关标签
  

闽ICP备14008679号