如何在nginx下配置ssl证书实现https访问,小白都会【超详细】
off999 2025-01-18 23:08 24 浏览 0 评论
为什么要配置https?
在互联网时代,信息泄露会给工作和生活带来很大的困扰,会源源不断的收到垃圾短信和各种推销电话和诈骗电话的骚扰。隐私泄露后可能会 让不法分子钻空子来获取你的信任从而使人更容易上当受骗。对于企业网站来说,不能保护好用户的隐私信息可能会面临行政罚款,同时还会损害企业的形象和声誉。
因此,企业网站应提前采取保护网络安全措施,防患于未然,而为网站部署SSL证书实现https加密是保护网络安全的基础。
尤其是微信开发、APP开发等都是强制的,SSL证书除了可以加快搜索引擎收录以外,还确保客户端与站点传输数据的加密作用,所有操作系统都可以部署。
http与https的区别
https相比http多了个s,这个“s”指的是secure(可翻译为安全的、可靠的),即http + 加密 + 认证 + 完整性保护 = https,其实就是多了ssl协议这层外壳的http,这就是它们最大的区别(如下图)。还有以下几点主要的区别:
- https协议需要申请CA证书,一般免费证书较少,因而需要一定费用。
- http是超文本传输协议,信息是明文传输,https则是具有安全性的ssl加密传输协议。
- http和https使用的是完全不同的连接方式,用的端口也不一样,前者是80,后者是443。
- http的连接很简单,是无状态的;https协议是有ssl + http协议构建的可进行加密传输、身份认证的网络协议,比http协议安全。
接下来就是从头开始配置https的全过程
一、环境说明
服务器系统:CenterOS 7
服务器IP:106.14.***.***(自己服务器的IP)
域名:shine***.cn(自己的域名)
二、添加域名解析
以阿里为例,在阿里云控制台=>产品域服务=>云解析DNS=>找到需要解析的域名,点击【解析】,进入解析页面后选择【添加解析】。
下图中第一、二个是域名常规配置,如已配请忽略,主要是第三个,是在申请证书验证时所需要的(具体所需要填的值后面步骤会提到)。
三、申请SSL证书
在阿里云控制台=>产品与服务=>安全(云盾)=>SSL证书,进入后点击【购买证书】。
如下图我选择的是“免费版DV SSL”,有1年的有效期。
确认购买后,点击证书列表里的【证书申请】
填写相关信息,从“域名验证方式”开始往下的默认就好
下一步,如果出现下图中错误提示,说明我在上面第二步提到的域名解析里没有添加第三个的解析。
解决办法则是,添加域名解析,“主机记录值“与”记录值“直接复制上图中的值就好,记录类型选择“TXT”,然后确认即可再次回到这里点击验证。
验证通过后,可能需要等待几分钟时间,等证书状态变为“已签发”,就可以下载了。
四、下载证书
在列表中找到已签发的证书,点击【下载】,选择nginx的进行下载
下载后,会得到一个压缩包,里面会有两个文件(.key和.pem文件)
五、登陆服务器,配置SSL证书
1.进入nginx安装目录:/usr/local/nginx (这是我服务器上nginx安装目录),新建cert/文件夹,把刚才下载的两个文件上传到cert/目录下。
2.在nginx/conf/目录下,编辑nginx配置文件nginx.conf(最好先做下备份),修改如下:
server {
listen 8082;
listen 8083 ssl; #这里原本默认是443端口,我自定义改用8083了,可以不改
server_name www.shine***.cn; #自己的域名
root /usr/local/nginx/html/baseManage; #这里是我自定义的访问根目录
ssl_certificate /usr/local/nginx/cert/3833729_www.shine***.cn.pem; #SSL配置 后面是写.pem文件所在的路径
ssl_certificate_key /usr/local/nginx/cert/3833729_www.shine***.cn.key; #SSL配置 后面是写.key文件所在的路径
ssl_session_cache shared:SSL:1m; #SSL配置
ssl_session_timeout 5m; #SSL配置
ssl_ciphers HIGH:!aNULL:!MD5; #SSL配置
ssl_prefer_server_ciphers on; #SSL配置
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}3.修改配置保存后,检查一下nginx配置文件是否可用,有successful输出表示可用。
$ nginx -t // 检查nginx配置文件这里,大多数可能是第一次安装https证书,就会出现报错,说是缺少SSL模块(如果没有提示缺少SSL模块,可以直接操作步骤4),如下图:
3.1这个时候我们就需要先安装SSL模块,目录切换到nginx源码包安装位置(就是有configure执行文件的目录下):
$ cd /usr/local/nginx3.2执行语句,安装SSL模块:
$ ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module3.3这时候可能又会有点小问题,启动SSL模块的时候报错了:
看到了error,就知道Linux安装失败,停止了。这个错误是因为我们没有安装openssl openssl-devel(如果没有这一步的报错的话,可以忽略跳过下面的3.4安装openssl-devel的步骤,直接操作3.5的步骤)
3.4执行安装openssl openssl-devel命令:
$ yum -y install openssl openssl-devel安装上openssl-devel后,重新执行./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
3.5配置成功后,那么就需要编译我们的配置。(注意:这里只能用make,而不要用make install,因为执行make install是覆盖安装的意思)
$ make等待执行完成后,我们需要把新编译的nginx模块替换原来的nginx。
3.6还是老规矩,先备份就的nginx执行文件(命令里的路径根据自己实际情况修改):
$ cp /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak3.7关闭nginx(因为要把新的模块覆盖就的nginx),通过命令找到进程号,在杀死该进程就可以了,执行命令:
$ ps -ef |grep nginx #查看进程号
$ kill -9 进程号3.8关闭nginx进程后就可以开始替换了,执行命令:
$ cp /usr/local/nginx/objs/nginx /usr/local/nginx/sbin/3.9然后就是启动nginx。
$ /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf因为刚才替换nginx模块时把nginx进程都kill掉了,所有要用上面的命令进行启动,而不是使用reload重启。
4.配置正确后,需要重新加载nginx配置文件才可以使修改的配置生效
$ nginx -s reload // 使配置生效到此,nginx的https访问就完成了。访问效果如下:
说明:如果访问不成功,则需要去检查实例的安全组,是否有配置开放对应的端口;如没有,则需要配置了才能访问(如默认的80、443端口或者自定义的端口)。
相关推荐
- 懂行的人建议买华为还是惠普电脑
-
华为电脑好。华为笔记本电脑主打的就是轻薄,质感,多屏协同生态,面向商务人群和学生党。目前在售的机型并不多,但每一台机子本身都不错,不过因为被制裁的缘故,定价过高,性价比打折扣。惠普笔记本好,惠普除了家...
- 如何把win系统换成安卓(怎么把系统改为win10)
-
方法/步骤分步:1首先点击打开酷安应用市场;2点击打开位于屏幕右下方的“应用游戏”选项;3选择想要下载的软件或者游戏app,点击进入;4选择“下载”按钮,点击开始下载;5APP下载完成后,系统会自动跳...
-
- 如何复制粘贴(如何复制粘贴excel表格内容)
-
需要复制文字的时候只要先选中文字,然后同时按住Ctrl+C键,然后松手就已经复制了文字,在需要粘贴的地方同时按住:Ctrl+V就可以看到文字被粘贴了,非常的方便。扩展资料:Alt键,这个键叫做改变,很多快捷键都需要使用到这个键,矩形...
-
2025-11-14 05:51 off999
- hotmail电子邮箱登录(hotmail邮箱在线登录)
-
***@hotmail.com1、其中***是你自己申请的邮箱的用户名。2、hotmail要写在符号@后面。3、最后加上.com,这样就是一个完整的hotmail邮箱的格式。4、比如:zhangj...
- win10iso文件(win10iso文件怎么安装)
-
安装Win10ISO系统文件需要以下步骤:1.首先需要从Microsoft官网下载Win10ISO系统文件,打开网站后选择Win10的版本、语言和架构(32位或64位),点击下载即可。2.下载...
- 英特尔显卡性能排行(英特尔显卡性能排行天梯图)
-
IRIS(英特尔第四/五代集成显卡)英特尔第四代集成显卡,分为HD4200/4400/4600,HD5100/5200。代号为GT2/3/3e,中文名为锐炬。hd420044004600和台式...
- 电脑做系统u盘启动选项(做系统开机u盘怎么选择)
-
操作须知:1、设置U盘启动分很多种:传统legacy机型设置、uefi新机型设置、uefi机型改legacy启动设置2、由于电脑品牌以及机型非常多,这边仅列举一部分电脑的设置方法,3、如果是uefi机...
- 未安装nvidia控制面板(电脑未安装nvidia控制面板)
-
如果你使用的是Nvidia显卡,但未安装Nvidia控制面板,则可能会遇到以下问题:1.无法进行高级显卡设置:Nvidia控制面板提供了高级显卡设置选项,例如显卡超频、显示器分辨率和刷新率、视频调整...
- u盘检测不到怎么修复(u盘检查不了是什么原因)
-
以下是可能的解决办法:1.更换不同的USB端口。有时候电脑某个USB端口可能出现问题,试试换一个不同的端口。2.重启电脑。有时候出现问题的USB端口可能需要重启才能正常。3.插拔几次U盘。有时候...
- win7 共享设置(win7共享设置详细步骤)
-
1.进入控制面板家庭组页打开控制面板找到网络和Internet下面的家庭组和共享选项并打开?2.进入更改高级共享设置打开以后选择更改高级共享设置功能进入?3.开启文件和打印机共享开启文件和打印机共享,...
- 电脑硬盘怎么装步骤图(电脑硬盘怎么装步骤图片)
-
1、查看硬盘的各项信息。硬盘的背面会有硬盘的存储容量以及电压,功率,转速等基本信息。2、购买到的一整块硬盘里面包括硬盘、对接线跟螺丝钉。将对接线和螺丝钉摆在一旁。3、在硬盘的上方会有两个SATA接口,...
- 小马win10永久激活(小马win10永久激活工具使用方法)
-
很简单,重装系统win7,这个可以激活的,然后根据推送升级win10,如果有强迫症可以升级以后重新安装win10系统,以后都是自动联网激活的。安全。小马激活工具win10版是小马专门为windowns...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
