前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nginx配置SSL实现https请求并重定向http请求的实现

Nginx配置SSL实现https请求并重定向http请求的实现

作者头像
Bug生活2048
发布2018-08-31 15:55:52
3.6K0
发布2018-08-31 15:55:52
举报
文章被收录于专栏:Bug生活2048

本篇文章主要记录下自己的博客网站实现https请求的步骤和自己遇到的一些问题。

环境说明

因为我的网站是部署在腾讯云上的,腾讯云同时也提供了免费的SSL证书(有效期1年)。

我们进入SSL证书管理控制台,点击【申请证书】

image

按照步骤就能申请对应的证书了。

DNS验证域名身份

腾讯云提供DNS验证域名身份,前提是你得开通DNS,然而DNS需要根据流量收费,对于我这个小博客来说不是很值得,所以没有忽略该方法。

这种方式无需你配置什么,只需要在控制台简单操作几步就可以了,具体可以参考腾讯云官方文档,这里就不过多介绍了。

Nginx 证书部署

首先到你的腾讯云下载你的证书www.***.com.zip的压缩包,解压后有不同服务器的证书文件,这里只要Nginx的就可以了

将Nginx文件中的1_www.***.com_bundle.crt2_www.***.com.key上传至你的服务器中,我将文件放在了/etc/nginx下。

接下来修改你的Nginx配置文件nginx.conf:

代码语言:javascript
复制
server {
        listen 443;
        server_name www.****.com; #填写绑定证书的域名
        ssl on;
        ssl_certificate 1_www.***.com_bundle.crt;
        ssl_certificate_key 2_www.***.com.key;
        ssl_session_timeout 5m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #按照这个协议配置
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;#按照这个套件配置
        ssl_prefer_server_ciphers on;
        location / {
            root   html; #站点目录
            index  index.html index.htm;
        }
    }

配置完成后,先用bin/nginx –t来测试下配置是否有误,正确无误的话,然后通过service nginx restart重启nginx。就可以使 https://www.****.com 来访问了。

这里有几个问题需要注意下:

  1. 配置文件的证书文件的地址一定要指定对,可能你没有放在Nginx的根目录下。
  2. 端口问题,http是80端口,但https是443,在配置nginx的时候千万别忘记修改端口。

相关参数说明供参考:

http自动跳转https

配置到这里如果没有意外的话已经可以通过https访问了,但可能很多用户还是会通过http访问,所以需要将你原来的http重定向到你的https上。

只需要在Nginx配置中加入下面配置:

rewrite ^ https://$http_host$request_uri? permanent;

但要注意的是,不是在你原来443端口下加,这样会死循环的,而是另外启个server,类似于下面的配置:

代码语言:javascript
复制
server {
        listen       80;
        server_name  www.***.com;
        rewrite ^ https://$http_host$request_uri? permanent;    # force redirect http to https
    }
server {
        listen 443;
        server_name www.****.com; #填写绑定证书的域名
        ssl on;
        ssl_certificate 1_www.***.com_bundle.crt;
        ssl_certificate_key 2_www.***.com.key;
        ssl_session_timeout 5m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #按照这个协议配置
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;#按照这个套件配置
        ssl_prefer_server_ciphers on;
        location / {
            root   html; #站点目录
            index  index.html index.htm;
        }
    }

这样就能实现重定向了。

如果想同时启用Http和Https,也可以这样配置:

代码语言:javascript
复制
server {
    listen              80;
    listen              443 ssl;
    server_name         www.***.com;
    ssl_certificate     www.***.com.crt;
    ssl_certificate_key www.***.com.key;
    ...
}
总结

配置的时候还是需要仔细,跟着步骤来,人品好的话一次就能搞定啦。大家可以亲身试验下。

最后推荐下我的博客,可点击原文查看:https://www.bug2048.com/

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-03-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Bug生活2048 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 环境说明
  • DNS验证域名身份
  • Nginx 证书部署
  • http自动跳转https
  • 总结
相关产品与服务
SSL 证书
腾讯云 SSL 证书(SSL Certificates)为您提供 SSL 证书的申请、管理、部署等服务,为您提供一站式 HTTPS 解决方案。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档