nginx的重定向(rewrite)

时间:2024-07-05 15:26:04

nginx的重定向(rewrite)

location 匹配

location匹配的就是后面的URI

/wordpress

192.168.60.20/wordpress

location匹配的分类和优先级

1、精确匹配 location = / 对字符串进行完全匹配,必须完全符合

2、正则匹配

^~ 前缀匹配,以什么为开头

~ 区分大小写的匹配

~* 不区分大小写

!~ 区分大小写的取反

!~* 不区分大小写的取反

3、一般匹配

location /字符串

精确匹配的优先级最高,其次是正则,最后是一般

优先级总结:
location = 完整路径   >   location  ^~  >   location ~      >     location /部分起始位置    >   location /
                                           location ~*

第一个规则:实际万战中的使用规则:

location  =   /  {
   root   html;
   index index.html index.htm index.php;
}
#网站首页

第二个必选的规则:处理静态请求的页面

location ^~ /static/ {
  root /web/static;
  index index.html  index.htm;
}
#用来匹配静态页面

图片:

loction ~* \.(jpg|gif|png|jpeg|css)$ {
   root /web/picture/;
   index index.html index.htm;
}
#访问图片或者是指定的后缀名

第三个规则:一般是通用规则,用来转发.php .js 为后缀的动态请求,动态请求到后端服务器(数据库)

location / {
  proxy_pass 
}
#用来转发后端请求和负载均衡

rewrite重定向:

rewrite就是把当前访问的页面跳转到其他页面。

rewrite的工作方式:通过nginx的全局变量或者自定义变量,结合正则表达式和标志位实现url的重定向。

nginx的变量

$uri 客户端请求的uri的地址

$host 请求的主机名

$http_user_agent 客户端请求的浏览器和操作系统

$http_referer 请求头的referer信息,表示当前页面来源的url

$remote_addr 客户端的ip地址

$remote_port 客户端的端口号

$server_addr 服务端的ip地址

$server_port 服务端的端口号

$request_method 获取客户端请求的方法

$scheme 请求的协议,要么是http要么是https

x_forwarded_for 用来获取请求头当中客户端的真实ip地址。代理服务器添加,在代理服务器当中只是客户端的ip地址

X-Real-IP 客户端真实的ip地址

proxy_set_header X-Real-IP $remote_addr 加上这伊字段,客户端必须带上真实的ip地址

标志位

flag

permanet 永久重定向,返回码是301,浏览器地址栏会显示跳转后的URL地址

redirect 临时重定向,返回码是302,浏览器地址栏会显示跳转后的URL地址

break 永久重定向,返回码也是301,但是他匹配到规则不会在向下匹配其他规则,URL也不会发生变化

last 重定向,但是会继续向下匹配其他的location规则

rewrite的执行顺序:

1、server模块的rewrite优先级最高

2、匹配location的规则

3、执行选定的location规则

rewrite的语法:

rewrite 正则表达式 跳转后的内容 标志位

rewrite or internal refirection cycle while processing?

在重定向的过程中,使用了last方式进行重定向,但是,没有结束,陷入的死循环,nginx会自动循环10次,last匹配最多只能执行10次,超过10次没有结束,就会停止,然后报错500。

实验1:

基于域名进行跳转,老头不用了,但是依然能够访问,统统跳转到新的域名

操作:

1、配置域名跳转

[root@test3 ~]# cd /usr/local/nginx/conf/
[root@test3 conf]# vim nginx.conf
   server {
        listen       80;
        server_name  www.xy102.com;
        charset utf-8;
        #access_log  logs/host.access.log  main;
        location / {
            root   html;
            if ( $host = 'www.xy102.com' ) {
                rewrite ^/(.*)$ http://www.zxc.com/$1 permanent;
            }
            index  index.html index.htm;
        }

2、将ip地址进行域名映射

[root@test3 ~]# vim /etc/hosts
192.168.60.30 www.xy102.com www.zxc.com

3、结果

实验2:

基于客户端的IP进行跳转 公司有新业务上线,测试阶段,其他的ip只能显示维护中,只有192.168.60.30能正常访问。

操作:

1、定义可以正常访问的ip地址

 35     server {
 36         listen       80;
 37         server_name  www.xy102.com;
 38     
 39         charset utf-8;
 40     
 41         #access_log  logs/host.access.log  main;
 42         set $rewrite true;
 43         #设置一个变量名,rewrite,值是true
 44         #来进行判断ip是否是合法ip
 45         if ( $remote_addr = "192.168.60.30" ) {
 46           set $rewrite false;
 47         } 
 48         if ( $rewrite = true ) {
 49           rewrite (.+) /error.html;
 50           #重定向,192.168.60.30/error.html       
 51         }
 52         location = /error.html {
 53          root html;
 54         }

2、在html目录下写一个网页维护中

[root@test3 html]# echo "网页维护中!" > error.html

3、test3结果

4、test4结果

location匹配的优先级

location = 精确

location ~ 正则

location / 一般

location /

重定向

permanent

refriect

break

last

500报错 10次