[特殊字符]使用 Nginx 将 HTTP 重定向到 HTTPS

随着互联网安全要求的提升,HTTPS(加密的 HTTP)已经成为现代网站的标配。但不少用户仍会通过 HTTP 访问网站,因此我们需要确保他们被自动重定向到 HTTPS。

本篇博客将介绍如何通过 Nginx 配置实现 HTTP 到 HTTPS 的自动重定向,并说明变量含义、注意事项及完整配置。


✳️ 为什么要从 HTTP 重定向到 HTTPS?

  • 安全性:HTTPS 提供了加密传输,防止中间人攻击。
  • SEO 友好:Google 明确表示优先收录 HTTPS 页面。
  • 浏览器兼容性:现代浏览器对 HTTP 页面标记为"不安全"。

🛠️ 环境准备

确保你已经具备以下条件:

  • 安装好的 Nginx(1.14+ 推荐)
  • 有效的 SSL 证书(如使用 Let's Encrypt)

📄 完整的 Nginx 配置示例(含重定向)

将下面文件放在 /etc/nginx/conf.d 并取名为 ssl.conf。

nginx 复制代码
# HTTP 服务器:监听 80 端口并重定向到 HTTPS
server {
    listen 80;
    server_name example.com www.example.com;

    # 永久重定向到 HTTPS
    return 301 https://$host$request_uri;
}

# HTTPS 服务器:监听 443 端口,启用 SSL
server {
    listen 443 ssl http2;
    server_name example.com www.example.com;

    # SSL 证书配置(以 Let's Encrypt 为例)
    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem; ##密钥所在服务器的绝对路径
    ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem; ##密钥所在服务器的绝对路径

    # 推荐的 SSL 配置
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers HIGH:!aNULL:!MD5;
    ssl_prefer_server_ciphers on;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }
}

🔍 $host$request_uri 是什么?

在配置中这行代码很关键:

nginx 复制代码
return 301 https://$host$request_uri;

它表示将所有 HTTP 请求永久重定向到 HTTPS。下面解释两个变量:

🔸 $host

  • 表示请求头中的 Host 字段
  • 代表用户请求的域名,比如 example.comwww.example.com
  • 如果没有显式的 Host 请求头,Nginx 使用 server_name 的第一个值。

🔸 $request_uri

  • 表示原始请求路径 + 查询字符串(如 /login?user=admin);
  • 不包含协议和主机信息,仅表示 URI 部分。

✅ 举例说明

用户请求:

复制代码
http://example.com/shop?id=123

Nginx 返回:

复制代码
HTTP/1.1 301 Moved Permanently
Location: https://example.com/shop?id=123

等效于:

nginx 复制代码
return 301 https://example.com/shop?id=123;

🧪 调试小技巧

如果你想临时查看 $host$request_uri 的值,可以添加如下调试配置:

nginx 复制代码
location /debug {
    return 200 "host: $host\nuri: $request_uri\n";
}

访问 http://example.com/debug 即可看到实际变量值。


✅ 总结

通过两段简单的配置,Nginx 就能实现自动将 HTTP 请求安全地重定向到 HTTPS,提高网站安全性和用户体验。

📌重点小结:

  • 使用 $host$request_uri 保留原始访问地址;
  • 使用 return 301 实现永久重定向;
  • 配置 HSTS 提高安全性;
  • 建议启用 HTTP/2 以提升性能。
相关推荐
知南x19 分钟前
【物联网视频监控系统----韦东山老师视频总结】(4)流媒体方案的实现之Nginx
物联网·nginx·音视频
不穿格子的程序员2 小时前
计算机网络篇1:OSI + HTTP进化史 + 三次握手四次挥手
网络协议·计算机网络·http
成为你的宁宁5 小时前
【Zabbix运维监控实战(附图文教程):Nginx 服务可用性、连接请求状态、CPU 内存占用与 JVM(Jar 包 / Tomcat)全维度监控】
运维·jvm·nginx·zabbix
特行独立的猫6 小时前
python+Proxifier+mitmproxy实现监听本地网路所有的http请求
开发语言·爬虫·python·http
CCPC不拿奖不改名6 小时前
基于FastAPI的API开发(爬虫的工作原理):从设计到部署详解+面试习题
爬虫·python·网络协议·tcp/ip·http·postman·fastapi
掘根6 小时前
【仿Muduo库项目】HTTP模块4——HttpServer子模块
网络协议·http·php
游戏开发爱好者87 小时前
2025年iOS应用上架App Store全指南,开发者必看
android·ios·小程序·https·uni-app·iphone·webview
Htojk7 小时前
openssl签发自签名证书的流程
网络协议·https·ssl
oMcLin7 小时前
如何在 Debian 11 上配置并调优 Nginx 与 Lua 脚本,提升高流量 API 网关的性能与安全性?
nginx·debian·lua
oMcLin7 小时前
如何在CentOS 8.4上配置并优化Nginx负载均衡,确保跨境电商平台的高并发请求稳定处理?
nginx·centos·负载均衡