Nginx return 响应码重定向

前提环境:

  • NGINX

涉及参考文档:

一、Nginx return 语法介绍

Syntax:	return code [text];
		return code URL;
		return URL;
Default:	—
Context:	server, location, if

停止处理并 将指定的返回code给客户端。非标准代码 444 关闭连接而不发送响应头。

: Nginx 版本 0.8.42 开始

  • return code URL 支持code 响应码: 301、302、303、307 和 308
  • return code [text] 支持code 响应码:204、400、402 — 406、408、410、411、413、416 和 500 — 504 以及 444 响应码
代码 307 直到版本 1.1.16 和 1.0.13 才被视为重定向。
代码 308 直到版本 1.13.0 才被视为重定向。


二、return code [text] 验证

Nginx 配置文件

server {
        listen       4444;
        server_name  _;
        charset      utf-8;
        root   /data/nginx/domain/;

        rewrite_log     on;  #开启rewrite重写规则默认写到error_log日志中,生产禁用,默认是关闭状态
        error_log       /var/log/nginx/bot-sca-error.log;
        access_log      /var/log/nginx/bot-sca-access.log testlog;

        location /444.html {
                return 444 "你的客户端IP地址是: $remote_addr";  # 设定客户端响应码为444,且返回客户地址IP
        }
}

在这里插入图片描述

修改Nginx 配置文件

server {
        listen       4444;
        server_name  _;
        charset      utf-8;
        root   /data/nginx/domain/;

        rewrite_log     on;
        error_log       /var/log/nginx/bot-sca-error.log;
        access_log      /var/log/nginx/bot-sca-access.log testlog;



        location /tz {
                return   http://www.baidu.com;  #默认响应码302
        }


        location /ips.html {
                return  200 "你的客户端IP地址是: $remote_addr";   # 设定客户端响应码为200,且返回客户地址IP
        }
}

在这里插入图片描述

总结:
return code [text] ,Nginx 配置中 设定 return code 状态码,客户端访问URI 返回相应的响应码。


三、return code URL 验证

Nginx 配置文件【code = 302】

server {
        listen       4444;
        server_name  _;
        charset      utf-8;
        root   /data/nginx/domain/;

        rewrite_log     on;
        error_log       /var/log/nginx/bot-sca-error.log;
        access_log      /var/log/nginx/bot-sca-access.log testlog;



        location /tz {
                return   http://www.baidu.com;  #默认响应码302
        }



        location /ips.html {
                return  200 "你的客户端IP地址是: $remote_addr";
        }


        location /aliyun {
                return   302  https://www.aliyun.com/; #临时重定向
        }
}

访问: http://192.168.11.100:4444/aliyun

  • 白屏访问 :

在这里插入图片描述
在这里插入图片描述

  • 黑屏访问 :
    在这里插入图片描述

Nginx 配置文件【code = 301】

server {
        listen       4444;
        server_name  _;
        charset      utf-8;
        root   /data/nginx/domain/;

        rewrite_log     on;
        error_log       /var/log/nginx/bot-sca-error.log;
        access_log      /var/log/nginx/bot-sca-access.log testlog;



        location /tz {
                return   http://www.baidu.com;  #默认响应码302
        }



        location /ips.html {
                return  200 "你的客户端IP地址是: $remote_addr";
        }


        location /aliyun {
                return   301  https://www.aliyun.com/; #永久重定向
        }
}

重新加载nginx配置:

 nginx -s  reload 

访问: http://192.168.11.100:4444/aliyun

  • 白屏访问 :

在这里插入图片描述
在这里插入图片描述

  • 黑屏访问 :
    在这里插入图片描述
总结:
将Nginx 配置文件修改访问到其他网站,一直访问也是阿里云的官方网址, 这就是301 永久重定向代码有关。 如果浏览器想访问修改重定向的网址需要清空浏览器的缓存。

四、HTTP 跳转 HTTPS 方案

NGINX 配置文件内容

server {
        listen       80 default_server;
        server_name  www.nginx-test.com *.nginx-test.com;
        return 302   https://$host$request_uri;
}


upstream sms-api {
        server 192.168.11.101 weight=3 max_fails=2  fail_timeout=20;
        server 192.168.11.102 weight=1 max_fails=2  fail_timeout=10;
}


server {
        listen           443 ssl;
        charset          utf-8;
        server_name      www.nginx-test.com *.nginx-test.com; #需要将yourdomain.com替换成证书绑定的域名。
        error_log        /var/log/nginx/bot-sca-error.log;
        access_log       /var/log/nginx/bot-sca-access.log testlog;
        ssl_certificate  /root/nginx.pem;  #需要将cert-file-name.pem替换成已上传的证书文件的名称。
        ssl_certificate_key  /root/nginx.key; #需要将cert-file-name.key替换成已上传的证书密钥文件的名称。
        ssl_session_timeout   5m;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
        #表示使用的加密套件的类型。
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #表示使用的TLS协议的类型。
        ssl_prefer_server_ciphers on;

        #return 301 https://$server_name$request_uri;
        #charset koi8-r;
        access_log  /var/log/nginx/host.access.log  main;
        location ^~ /sms/api {
            proxy_set_header Host $host;                 #默认情况下反向代理是不会转发请求的Host头部。如果需要转发,就要添加此条配置
            proxy_set_header X-Real-IP $remote_addr;     #在web服务器端获得用户的真实,ip$remote_addr——客户地址
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #如果客户端请求标头中不存在“ X-Forwarded-For”字段,则该$proxy_add_x_forwarded_for变量等于该$remote_addr变量。
            proxy_pass http://sms-api/;
    }
}
  • 默认 URL/URI 访问 [80端口访问]

在这里插入图片描述
在这里插入图片描述

  • 访问 URI = /sms/api 响应
    在这里插入图片描述

在这里插入图片描述

总结:

1  return code [text]   Nginx 配置中 设定 return   code 状态码,客户端访问URI 返回相应的响应码。 
2  return code URL      这就是301 永久重定向代码有关。 如果浏览器想访问修改重定向的网址需要清空浏览器的缓存。
3  return 指令一般用于对请求的客户端直接返回响应状态码。
<think>嗯,用户想了解Nginx的URL重定向,我得先理清楚这个主题的关键点。首先,我应该从基本概念开始,解释什么是URL重定向,为什么需要它。然后,可能需要介绍常见的重定向类型,比如301和302的区别,用户可能不太清楚这些状态码的意义。 接下来,用户可能需要具体的配置方法。我应该涵盖几种常见的重定向场景,比如整个站点的重定向、特定路径的重定向、HTTPS强制跳转,还有带参数的重定向处理。每个场景给出示例配置,这样用户可以直接参考使用。 另外,用户可能会遇到需要正则表达式的情况,这部分需要详细说明,比如如何捕获分组并在重定向中使用。还要注意语法是否正确,比如Nginx中if语句的使用限制,避免常见的配置错误。 可能还需要提到一些高级技巧,比如根据请求方法或参数进行条件重定向,但得确认这些是否是用户需要的。不过作为基础介绍,可能先覆盖常见的情况更合适。 最后,要确保回答结构清晰,分步骤说明,让用户能逐步理解和应用。同时,提醒用户测试配置的重要性,避免上线后出现问题。可能还需要强调检查语法和重启Nginx服务的步骤,帮助用户避免常见陷阱。</think>好的,我将分步骤为您介绍Nginx的URL重定向实现方法: 一、重定向基础概念 URL重定向(URL Redirection)是将一个URL请求自动转向到另一个URL的技术,常见场景包括: 1. 网站改版后的旧链接跳转 2. HTTP强制跳转HTTPS 3. 域名变更 4. 路径规范化(如统一尾部斜杠) 二、Nginx配置重定向的核心指令 ```nginx return 状态码 目标URL; rewrite 正则表达式 替换目标 [flag]; ``` 三、常见重定向场景实现 1. 全站HTTP跳转HTTPS(301永久重定向) ```nginx server { listen 80; server_name example.com; return 301 https://$host$request_uri; } ``` 2. 特定路径重定向 将 `/old-page` 重定向到 `/new-page`: ```nginx location = /old-page { return 301 https://example.com/new-page; } ``` 3. 带参数重定向 保留请求参数的跳转: ```nginx location /search { return 301 https://search.example.com$request_uri; } ``` 4. 正则表达式重定向 ```nginx # 匹配数字路径跳转 rewrite ^/item/(\d+)$ /products/$1 permanent; # 尾部斜杠规范化 rewrite ^/(.*)/$ /$1 permanent; ``` 四、高级应用技巧 1. 条件判断重定向 ```nginx if ($http_user_agent ~* "bot") { rewrite ^/(.*)$ /bot-page/$1 redirect; } ``` 2. 多域名统一跳转 ```nginx server { listen 80; server_name example.net www.example.org; return 301 https://example.com$request_uri; } ``` 五、注意事项 1. 状态码选择: - 301(永久重定向):SEO友好,浏览器会缓存 - 302(临时重定向):不缓存,用于测试环境 2. 正则表达式优先级: - `=` 精确匹配 > `^~` 前缀匹配 > 正则匹配 > 通用匹配 3. 建议测试顺序: ```bash nginx -t # 检查配置语法 systemctl reload nginx # 平滑重载配置 ``` 六、调试技巧 使用curl验证响应头: ```bash curl -I http://example.com/old-path ``` 预期输出应包含: ``` HTTP/1.1 301 Moved Permanently Location: https://example.com/new-path ``` 实际应用时,请根据具体需求调整正则表达式和跳转逻辑。如果遇到特定场景的重定向需求,可以提供详细信息,我可以给出针对性配置建议。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值