Nginx return 响应码重定向

前提环境:

  • NGINX

涉及参考文档:

  • Nginx官方文档 —— ngx_http_rewrite_module

一、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 return 响应码重定向_第1张图片

修改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
        }
}

Nginx return 响应码重定向_第2张图片

总结:
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 return 响应码重定向_第3张图片

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

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 return 响应码重定向_第4张图片
Nginx return 响应码重定向_第5张图片

  • 黑屏访问 :
    Nginx return 响应码重定向_第6张图片
总结:
将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端口访问]

Nginx return 响应码重定向_第7张图片
Nginx return 响应码重定向_第8张图片

  • 访问 URI = /sms/api 响应
    Nginx return 响应码重定向_第9张图片

Nginx return 响应码重定向_第10张图片

总结:

1  return code [text]   Nginx 配置中 设定 return   code 状态码,客户端访问URI 返回相应的响应码。 
2  return code URL      这就是301 永久重定向代码有关。 如果浏览器想访问修改重定向的网址需要清空浏览器的缓存。
3  return 指令一般用于对请求的客户端直接返回响应状态码。

你可能感兴趣的:(NGINX,初级篇,kubernetes,nginx,运维)