CentOS环境下Nginx配置SSL证书实现https请求详解
(资料图)
目录
一、证书申请二、配置SSL2.1 证书上传2.2 Server配置2.3 配置转发三、配置问题3.1 ngx_http_ssl_module3.2 ERR_SSL_PROTOCOL_ERROR四、配置示例4.1 SSL完整配置一、证书申请
申请SSL证书,申请之后会有两个文件提供下载(注意下载nginx版本),阿里云有免费的SSL证书申请xxx.keyxxx.pemnginx安装版本使用的是1.16.1二、配置SSL
2.1 证书上传
在nginx的安装目录下创建cert(别的名字也可以)将下载的SSL证书文件上传到cert下2.2 Server配置
进入到nginx下的conf文件夹下打开nginx.conf文件取消https server的注释# HTTPS server server { listen 443 ssl; server_name localhost; ssl_certificate cert.pem; ssl_certificate_key cert.key; ssl_session_cache shared:SSL:1m; ssl_session_timeout 5m; ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; location / { root html; index index.html index.htm; } }需要配置一下说明的内容
# HTTPS server server { # 注意这里就是443 ssl, 不要把ssl删除了 listen 443 ssl; # 把localhost替换为SSL绑定的域名, 如www.codecoord.com # server_name localhost; server_name www.codecoord.com; # 添加默认主目录和首页, 根据自己的路径修改 root /opt/nginx/html; index index.html; # cert.pem和cert.key替换为上传文件的路径(最好使用完整路径) # ssl_certificate cert.pem; # ssl_certificate_key cert.key; ssl_certificate /opt/nginx/cert/cert.pem; ssl_certificate_key /opt/nginx/cert/cert.key; # 下面的不用动 ssl_session_cache shared:SSL:1m; ssl_session_timeout 5m; ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; location / { root html; index index.html index.htm; } }注意443端口需要在开启外网访问(比如阿里云服务器需要在控制台配置安全组, 不过默认是打开的)
2.3 配置转发
这一步是配置对外访问端口和将http请求强制转为https删除多余配置,只需要留下以下配置server { # 监听端口 listen 80; # 改为自己的域名 server_name www.codecoord.com; # 将http请求强制转为https # rewrite:重写指令,$host$:请求地址,$1:请求参数,permanent:永久访问 rewrite ^(.*)$ https://$host$1 permanent; }
上述两步配置完成后测试一下是否配置正确,在sbin目录下运行测试命令
./nginx -t# 配置成功信息 [root@TianXin sbin]# ./nginx -t nginx: the configuration file /opt/Nginx/conf/nginx.conf syntax is ok nginx: configuration file /opt/Nginx/conf/nginx.conf test is successful如果测试成功则重启nginx,使配置生效
[root@TianXin sbin]# ./nginx -s reload完整配置参考第四点配置示例配置完成后访问域名,即可显示https信息
三、配置问题
3.1 ngx_http_ssl_module
注意如果是nginx 1.16.1之前版本, 配置内容会有有所变化,请参考别的版本配置如果运行./nginx -t时出现以下错误,标识nginx没有安装SSL模块[root@tianxin conf]# nginx -t nginx: [emerg] the "ssl" parameter requires ngx_http_ssl_module in /opt/nginx/conf/nginx.conf:112 nginx: configuration file /opt/nginx/conf/nginx.conf test failed解决方法是重新配置nginx,重新编译带上--with-http_stub_status_module --with-http_ssl_module可以重新安装nginx(建议, 可以避免很多问题)也可以不用重新安装, 不用重新安装只需要执行下面的两个命令即可
# 清除编译文件 make clean # 配置 ./configure --prefix=/opt/nginx --with-http_stub_status_module --with-http_ssl_module # 编译 make不要执行make install 否则会覆盖原来的文件关闭nginxnginx -s stop拷贝目录下的objs/nginx替换之前的nginx启动文件cp objs/nginx /opt/nginx/sbin/最后启动nginx即可
3.2 ERR_SSL_PROTOCOL_ERROR
此问题在该版本中出现是因为listen配置的时候把443 后面的ssl删除了导致这个错误server { # 注意这里就是443 ssl, 不要把ssl删除了,之前的版本 listen 443 ssl; ... }解决方法就是不要把443后面的ssl漏了,注意中间有空格
四、配置示例
4.1 SSL完整配置
#user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name www.codecoord.com codecoord.com; rewrite ^(.*)$ https://$host$1 permanent; } # https server { # 注意这里就是443 ssl, 不要把ssl删除 listen 443 ssl; # 替换为SSL绑定的域名, 如www.codecoord.com server_name www.codecoord.com; # 添加默认主目录和首页, 根据自己的路径修改 root /opt/nginx/html; index index.html; # cert.pem和cert.key替换为上传文件的路径 ssl_certificate /opt/nginx/cert/www.codecoord.com.pem; ssl_certificate_key /opt/nginx/cert/www.codecoord.com.key; # 下面的不用动 ssl_session_cache shared:SSL:1m; ssl_session_timeout 5m; ssl_ciphers HIGH:!aNULL:!MD5; ssl_prefer_server_ciphers on; location / { root html; index index.html index.htm; try_files $uri $uri/ /index.html; # 解决vue页面刷新404问题 } } }
以上就是Nginx实战-配置SSL证书(CentOS环境),实现https请求的详细内容,更多关于Nginx配置SSL实现https请求的资料请关注脚本之家其它相关文章!
关键词:
责任编辑:宋璟
-
CentOS环境下Nginx配置SSL证书实现https请求详解
-
每日快看:浓情五月 繁江小学学子感恩母爱
-
全球要闻:安帅为曼城备下战术套餐!瓜帅不怕皇马,六中场等你来破
-
天天速读:iPhone如何切换其它的地区 苹果手机怎么切换其他地区
-
狗头什么意思啊 狗头什么意思
-
世界即时:金融春雨“润”“三农”,重庆市涉农贷款突破8000亿元
-
报道:看了49岁刘琳的打扮,我悟了:不穿红戴绿、不乱烫发,更优雅气质
-
全球最新:多地五月强降雨,今年防汛形势如何?
-
全球热资讯!家常酸菜鱼的做法视频 家常酸菜鱼最正宗的做法
-
快资讯:太阳VS掘金天王山之战:保罗因腹股沟拉伤继续缺席
-
一群平均年龄51岁的“姐姐”决定乘风破浪
-
【网友建议】地铁19号线在孙村组团规划线路!官方回复说… 世界观察
-
百顺汽车保养地址(百顺汽车保养店官网)|资讯推荐
-
河北汇华学院官网首页_河北汇华学院官网 快消息
-
今日精选:ki值抑制常数的意义_ki值
-
天天热消息:谷歌浏览器 xp版下载_谷歌浏览器稳定版xp
-
小鸡宝宝考考你宋朝一位女子“击鼓退金兵”的故事为人熟知,她的名字是
-
回迁房八年住不上 愁坏包头八旬夫妇!到底咋回事....(附视频) 全球微动态
-
云无心以出岫鸟倦飞而知还赏析 云无心以出岫鸟倦飞而知还
-
赵匡胤与弟弟练箭,弟弟射到皇嫂,赵匡胤没生气却还夸:射得好!_快报
-
浙江嘉兴一工地吊车倒塌,应急局:1人不幸身亡,将通报
-
中秋节给领导祝福语_希望能帮助到您|环球新动态
-
308股今日获机构买入评级 12股上涨空间超50% 最新消息
-
基金调研丨鑫元基金调研芳源股份
-
淄博:一季度实现生产总值1057.70亿元,同比增长4.7% 焦点速读
-
隆基绿能对二季度硅片盈利保持乐观预期|世界新消息
-
物流市场信心继续增强 4月物流业景气指数为53.8% 环球聚看点
-
宋清辉:保险的三大特征显而易见 保险投资可以作为长期理财工具
-
厉害了!城阳分局夺得全市公安机关禁毒系统大比武冠军-热点评
-
速度扩散!西安这笔钱可以申请了!|当前滚动
-
1小时只需要30度电,卡特彼勒电动装载机首次亮相长沙国际工程机械展
-
中国国企ETF(517180)涨3.20%,中国铁建涨5.37%,招商公路涨4.42%|每日观点
-
上海一所高校大学生导师搭起沪藏两校空中课堂
-
环球快看:异动快报:宁沪高速(600377)5月8日11点11分触及涨停板
-
全球热讯:鄂尔多斯市内培外引打造龙头领航强磁场