使用自签发证书实现Nginx HTTPS

 为了互联网安全HTTS化势在必行,但是证书首先需要花钱购买,虽然有很多免费证书可以申请,但而且还必须要有个域名才能通过验证。实际中我们有一些内部的系统或者某些测试环境没有域名或者无需设置域名,这种情况下如何使用HTTPS呢,那就是本文虫虫要给大家介绍的自签名证书方式。

[[262081]]

安装升级openSSL

OpenSSL是整个底层加密算法库和工具的基础。

我们的Web服务器要依赖它的类库来实现SSL/TSL模块和HTTPS的工作。在签发证书时候也需要使用OpenSSL。在自签名生成时候,我们可以使用其他更加专业的软件,比如GPG,关于GPG使用我们以前文章中介绍过,大家可以参考历史文章。本文为了方便,证书的签发都用OpenSSL。

由于OpenSSL升级可能影响很多软件,我们先不直接升级,而生成一个新版本的OpenSSL在/usr/local/ssl目录,这样不影响已有有版本的其他软件。

首先下载新版本的OpenSSL,为了兼容我们选择1.0.2系列版本:

  1. wget Url --no-check-certificate 
  2. tar -zxvf openssl-*.tar.gz 
  3. cd openssl-* 
  4. ./config -fpic shared && make && make install 
  5. echo "/usr/local/ssl/lib" >> /etc/ld.so.conf 
  6. ldconfig 

生成自签名证书

子签名证书的使用商用证书一样,不过证书需要自己生成。首先确保OpenSSL升级到新版本,或者通过yum update openssl升级确保解决已有的ssl漏洞。

  1. mkdir /etc/ssl 
  2. chmod 700 /etc/ssl 
  3. /usr/local/openssl/bin/openssl req -newkey rsa:2048 -nodes -keyout /etc/ssl/rsa_private.key -x509 -days 888 -out cert.crt -subj /C=CN/ST=BJ/L=CY/O=CC/OU=OP/CN=Chongchong/[email protected] 

为了避免创建证书过程中的交互式信息填写,我们此处使用-subj参数指定了一些参数,实际使用中可以根据需要自己设置:

 

 

C=CN ← 国家代号,中国输入CN

ST=BJ ← 州(省)名

L=CY ← 所在地市的名称

O=CC ← 组织或者公司名称

OU=OP ← 部门名称

CN=Chongchong ← 通用名,可以是服务器域控名称,或者个人的名字

[email protected] ← 管理邮箱名

会生成网站私钥rsa_private.key和网站证书cert.crt都准备完毕。证书的验证可以在设置成功后。为了证书安全设置权限:

chmod 600 /etc/ssl/*

Nginx HTTPS安全配置

确保nginx使用新版本的nginx(目前版本为1.15.11,1.12.2),如果系统是用的其他应用服务器,一般做法是给新增加nginx做为反向代理,代理到应用服务器,比如tomcat,然后在Nginx反向代理商配置https。

新开一个虚拟主机,并在server{ .. . }段中设置:

注意nginx新语法中已经不使用ssl on;而是在listen语句中添加ssl;443为默认https端口,根据实际情况修改为别的。

listen *:443 ssl;

  1. ssl_certificate / etc/ssl/cert.crt; 
  2. ssl_certificate_key / etc/ssl/rsa_private.key
  3. ssl_protocols TLSv1.2; 
  4. ssl_prefer_server_ciphers on
  5. ssl_ciphers "EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH"
  6. ssl_ecdh_curve secp384r1; 
  7. ssl_session_cache shared:SSL:10m; 
  8. ssl_session_tickets off
  9. add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload"

其中的路径是刚刚生成的网站证书的路径。根据网站实际情况配置可能有差异,我们可以使用Mozilla的服务器端TLS配置在线生成器,这个我们以前的文章中也提到过:

 

 

配置完成后,使用nginx命令检测配置和重新加载Nginx:

检测配置:

  1. nginx -t 

重新加载:

  1. nginx -s reload 

Nginx优化配置

优化Nginx性能

在http{.. .}中加入:

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

增加session缓存可以提高nginx处理https的性能。

在配置https的虚拟主机server{.. .}中加入:

  1. keepalive_timeout 70; 

设置超时,可以由于超时导致等待导致性能问题

fastcgi ssl配置

有时候启用https后,有些php程序认证通过后,出现跳转页面错误错误,跳转到http导致问题。

解决方法是定位至”location ~ .*.(php|php5)?${}”在include fcgi.conf;或者在fastcgi_param配置后面加上:

  1. fastcgi_param HTTPS on
  2. fastcgi_param HTTP_SCHEME https; 

浏览器添加网站信任

使用自签名的https证书,默认浏览器是拒绝访问的,需要把该网站添加到浏览器信任列表才能访问。

添加信任的方法:

firefox

点击高级,将要访问url添加到信任即可:

 

 

Chrome

Chrome设置类似,点击高级

 

 

点击继续前往

 

 

证书验证

查看我们自签名的证书信息:

 

 

和第二部我们生成证书时候设置的参数一致。

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/149223.html<

(0)
运维的头像运维
上一篇2025-03-12 12:38
下一篇 2025-03-12 12:39

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注