侧边栏壁纸
博主头像
逢尔Seyu 博主等级

星光不负赶路人,时光不负追梦人

  • 累计撰写 30 篇文章
  • 累计创建 20 个标签
  • 累计收到 2 条评论

目 录CONTENT

文章目录

Nginx的rewrite重写

逢尔Seyu
2023-12-19 / 0 评论 / 0 点赞 / 41 阅读 / 0 字

rewrite重写概述

Rewrite主要实现url地址重写,以及重定向,就是把传入web的请求重定向到其他url的过程。

rewrite重写使用场景

1、地址跳转,用户访问www.test.com这个URL时,将其定向至一个新的域名mobile.test.com
2、协议跳转,用户通过http协议请求网站时,将其重新跳转至https协议方式
3、伪静态,将动态页面显示为静态页面方式的一种技术,便于搜索引擎的录入,同时减少动态URL地址对外暴露过多的参数,提升更高的安全性。
4、搜索引擎,SEO优化依赖于url路径,好记的url便于支持搜索引擎录入

rewrite配置示例

句法:Syntax:  rewrite regex replacement [flag]
默认:Default: --
语境:Context: server,location,if

#用于切换维护页面场景
#rewrite ^(.*)$ /page/maintain.html break;

rewrite标记Flag

rewrite指令根据表达式来重定向URL,或者修改字符串,可以应用于server,location,if环境下,每行rewrite指令最后跟一个flag标记,支持的flag标记有如下表格所示:

flag

作用

last

本条规则匹配完成后,停止匹配,不再匹配后面的规则

break

本条规则匹配完成后,停止匹配,不再匹配后面的规则

redirect

返回302临时重定向,地址栏会显示跳转后的地址

permanent

返回301永久重定向,地址栏会显示跳转后的地址

last与break区别对比示例

vim nginx.conf        
server {
        listen 80;
        server_name rewrite.test.com;
        root /code/test/;

        location / {
        rewrite /1.html /2.html; 
		#rewrite /1.html /2.html last; last表示匹配到这个规则后,当前location里的规则就不匹配了 
		#rewrite /1.html /2.html break; break表示就匹配到当前,后面的所有规则都不进行匹配
        rewrite /2.html /3.html; 
        }

        location /2.html {
        rewrite /2.html /a.html;
        }

        location /3.html {
        rewrite /3.html /b.html;
        }
    }

redirect和permanent区别对比

redirect(302): 每次请求都会询问服务器,如果当服务器不可用时,则会跳转失败。

permanent(301): 第一次请求会询问,浏览器会记录跳转的地址,第二次则不再询问服务器,直接通过浏览器缓存的地址跳转。

server {
        listen 80;
        server_name rewrite.test.com;
        root /code;

        location /test {
                rewrite ^(.*)$  http://xwutx.cn redirect;
                #rewrite ^(.*)$  http://xwutx.cn permanent;
                #return 301 http://xwutx.cn;
                #return 302 http://xwutx.cn;
        }
}

对比结果

425207E2-03D3-4908-8530-E6C7A30F4B19.jpgFFB5A0C0-DFA0-446E-B189-0C8143D33776.jpg

案例一

用户访问/abc/1.html实际上真实访问的是/ccc/bbb/2.html

#http://www.test.com/abc/1.html  ==>  http://www.test.com/ccc/bbb/2.html

#1.准备真实访问路径
mkdir /code/ccc/bbb -p
echo "ccc_bbb_2" > /code/ccc/bbb/2.html

#2.Nginx跳转配置
cd /etc/nginx/conf.d/
vim ccbb.conf 
server {
        listen 80;
		server_name www.test.com;

        location / {
                root /code;
                index index.html;
        }
        location /abc {
                rewrite (.*) /ccc/bbb/2.html redirect;
                #return 302 /ccc/bbb/2.html;
        }
}

#3.重启Nginx服务
nginx -t
#nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
#nginx: configuration file /etc/nginx/nginx.conf test is successful
nginx -s reload

案例二

用户用户访问/test实际上真实访问的是https://www.xwutx.cn

#1.Nginx跳转配置
[root@web03 conf.d]# cat test.conf 
server {
        listen 80;

        location /test {
                rewrite (.*) https://www.xwutx.cn redirect;
        }
}

#2.重启nginx服务
[root@web03 conf.d]# nginx -s reload

案例三

http请求跳转到https

#Nginx跳转配置
server {
        listen 80;
        server_name www.test.com;
        rewrite ^(.*) https://$server_name$1 redirect;
        #return 302 https://$server_name$request_uri;
}       

server {
        listen 443 ssl;
        server_name www.xwutx.cn;
}



#变量使用
#案例1:需要在跳转后的请求行加上想要的参数&showoffline=1
server {
    listen 80;
    server_name www.test.com;
    # $args为Nginx内置变量请求行的参数
    set $args "&showoffline=1";
    location / {
    root /code;
    index index.html;
    }
    if ($remote_addr = 10.0.0.1 ){
    rewrite (.*) http://www.test.com$1;
    }

}
#案例2:网站维护,指定IP正常访问,其他IP跳转维护页面
server {
    listen 80;
    server_name www.test.com;
    root /code;
    charset utf-8,gbk;

    location / {
        index index.html;
        set $ip 0;       # 设置变量为0
        if ($remote_addr = "10.0.0.1"){
            set $ip 1;   # 如果来源IP为0.1则设置为1
        }
        if ($ip = 0){    # 判断如果变量为0 则跳转维护页面
            rewirte ^(.*)$ /wh.html break;
        }
    }


}


Nginx内置参数
$args           #这个变量等于请求行中的参数。
$content_length #请求头中的Content-length字段。
$content_type   #请求头中的Content-Type字段。
$document_root  #当前请求在root指令中指定的值。
$host           #请求主机头字段,否则为服务器名称。
$http_user_agent #客户端agent信息
$http_cookie    #客户端cookie信息
$limit_rate      #这个变量可以限制连接速率。
$request_body_file #客户端请求主体信息的临时文件名。
$request_method     #客户端请求的动作,通常为GET或POST。
$remote_addr     #客户端的IP地址。
$remote_port     #客户端的端口。
$remote_user    #已经经过Auth Basic Module验证的用户名。
$request_filename #当前请求的文件路径,由root或alias指令与URI请求生成。
$query_string   #与$args相同。
$scheme         #HTTP方法(如http,https)。
$server_protocol                 #请求使用的协议,通常是HTTP/1.0或HTTP/1.1。
$server_addr        #服务器地址,在完成一次系统调用后可以确定这个值。
$server_name     #服务器名称。
$server_port    #请求到达服务器的端口号。
$request_uri     #包含请求参数的原始URI,不包含主机名,如:”/foo/bar.php?arg=baz”。
$uri            #不带请求参数的当前URI,$uri不包含主机名,如”/foo/bar.html”。
$document_uri   #与$uri相同。

$X-Forwarded-For:HTTP的请求端真实的IP,只有在通过了HTTP 代理或者负载均衡服务器时才会添加该项。标准格式如下:X-Forwarded-For: client1, proxy1, proxy2

0

评论区