概述
title: 在Nginx中让所有HTTP请求转发到HTTPS
date: 2017-10-23 20:50:24
tags:
- nginx
- http
- https
categories: - 运维
背景
在启用HTTPS协议的网站上,通常会让用户始终以 https://
访问,那怎样来实现这个需求呢?首次想到的是在应用代码中实现,但如果后端应用比较多时添加会比较繁琐,另外应用层应该专注业务实现,所以这并不是最合理的方案。试想如果能够将请求流量阻挡的越早肯定会越合理,所以可以在Nginx中配置转发逻辑。
前提
在做这件事情的前提是你已经完成证书安装,通过 https://
协议能够正常访问网站。
步骤
- 找到Nginx配置文件或网站的Server配置子文件,再添加一个Server用来监听
80
端口,如果用户不以https://
协议访问网站,则请求会被80
端口监听到。server { listen 80 default_server; listen [::]:80 default_server; server_name example.com www.example.com; }
- 添加301状态到响应中,诱使浏览器自动进行跳转。
server { listen 80 default_server; listen [::]:80 default_server; server_name example.com www.example.com; return 301 https://$server_name$request_uri; }
- 保存之后重启Nginx服务,如果遇到错误可查询日志确认问题,我在配置是就遇到
default_server
被重复定义的问题,此时只要把多余的监听删除即可。
最后
以上就是忧心小蚂蚁为你收集整理的在Nginx中让所有HTTP请求转发到HTTPS背景前提步骤的全部内容,希望文章能够帮你解决在Nginx中让所有HTTP请求转发到HTTPS背景前提步骤所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复