nginx的重定向(rewrite)
一、location
1、 location匹配
location匹配的就是后面的URI
/wordpress
192.168.100.11/wordpress
2、 location匹配的分类
2.1 精确匹配
location = / 对字符串进行完全匹配,必须完全符合
2.2 正则匹配
^~
前缀匹配,以什么为开头
~
区分大小写的匹配
~*
不区分大小写
!~
:区分大小写的取反
!~*
:不区分大小写的取反
2.3 一般匹配(通用匹配)
location /字符串
3、location匹配优先级*
精确匹配的优先级最高、其次正则,最后一般匹配
3.1 匹配优先级实验
systemctl stop firewalld
setenforce 0
systemctl restart nginx
cd /usr/local/nginx/html/
把照片拖进去
vim /usr/local/nginx/conf/nginx.conf
location = /1.jpg {
root /data/nginx/static1;
index index.html;}
location /1.jpg {
root /data/nginx/static2;
index index.html;}
location ~*\.(jpglgif)$ {
root /data/nginx/static3;
index index.html;}
wq!
nginx -t
systemctl restart nginx
mkdir-p /data/nginx/static1
cd /data/nginx #查看只有一个static1mkdir static2 static3 #查看此时有static1 static2 static3cd /usr/local/nginx/static1/
把1.jpg拖进去
cd /usr/local/nginx/static2/
把2.jpg拖进去
cd /usr/local/nginx/static3/
把3.jpg拖进去
[root@localhost static3]# mv 3.jpg 1.jpg[root@localhost static3]# ls1.jpg
页面访问
192.168.100.11/1.jpg # 此时访问的是1.jpg的图片
页面访问
把精确匹配注释掉
nginx -t
systemctl restart nginx
192.168.100.11/1.jpg # 此时访问的是3.jpg的图片
3.2 优先级总结
location = 完整路径 = 1.jpg即完整的一个字也不能少
location
^~
、
location ~
location ~*
、location /(字符串)部分起始位置、location /
4、实际网站中的使用规则
第一个必选规则
网站首页用精确等于杠(= /)
1.1 网站首页
location = / {
root html;
index index.html index.htm index.php;}# = / 表示家目录的开头,访问= /相当于访问网站首页
第二个必选规则
处理静态请求的页面
1.2 用来匹配静态页面
location ^~ /static/ {
root /web/static/;
index index.html index.htm;}
1.3 访问图片或者指定的后缀名
location ~* \.(jpg|gif|jpeg|png|css)$ {
root /web/pictures/;
index index.html index.htm;}
第三个必须规则
一般是通用规则,用来转发.php .js为后缀的动态请求到后端服务器(数据库)
1.4 转发后端请求和负载均衡
location / {
proxy_pass
}
二、rewrite重定向
1、概念
rewrite就是把当前访问得页面跳转到其他页面。
2、工作方式
通过nginx的全局变量或者是自定义变量,结合正则表达式和标志位实现url的重定向。
3、nginx的变量
$uri
:客户端请求的url地址
$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地址
4、nginx真实ip地址访问设置
vim nginx.conf
proxy_set_header X Real-IP $remote_addr# 加上这字段,客户端的真实ip地址就会传递给后端服务器
操作
vim /usr/local/nginx/conf/nginx.conf
在server模块修改,修改如下
location / {
root html;
default_type text/plain;return200"ip:$remote_addr";}
wq!
systemctl restart nginx
页面访问 192.168.100.11
#此时显示的是本机地址 ip 192.168.100.1# return 200 "ip:$remote_addr\ntest1:$host\nport:$remote_port\nxieyi:$scheme";
systemctl restart nginx
页面访问
# ip:192.168.100.1# test1:192.168.100.11# port:51360# xieyi:http
5、标志位(flag)
permanent
:永久重定向,返回码是301,浏览器地址栏会显示跳转后的url地址
redirect
:临时重定向,返回码是302,浏览器地址栏会显示跳转后的url地址
break
:永久重定向,返回码是301,但是她匹配到规则之后不会再向下匹配其他规则,url也不会发生变化
last
:重定向,但是会继续向下匹配其他的location规则
6、rewrite的执行顺序
6.1 server模块的rewrite的优先级最高
6.2 匹配location的规则
6.3 执行选定的location规则
7、rewrite的语法
rewrite 正则表达式 跳转后的内容 标志位;
7.1 实验
cd /usr/local/nginx/html
mkdir test1
mkdir xy102
cd /usr/local/nginx/html/test1
echo123> index.html
cd /usr/local/nginx/html/xy102
echo456> index.html
# 查看一下test1和xy102目录下的index.html是否创建(1)vim /usr/local/nginx/conf/nginx.conf
在server模块修改,修改如下
location / {
root html;
rewrite /test1/(.*) /xy102/$1 permanent;#192.168.100.11/test1/index.html 192.168.100.11/xy102/index.html $1就是捕获组
index index.html;}
wq!
nginx -t
systemctl restart nginx
页面访问
192.168.100.11/test1
# 访问结果为456,网站ip跳转为192.168.100.11/xy102(2)vim /usr/local/nginx/conf/nginx.conf
在server模块修改,修改如下
location /test1 {
root html;
rewrite /test1/(.*) /test2/$1 last;
index index.html;}
location /test2 {
root html;
rewrite /test2/(.*) /test1/$1 last;
index index.html;}
wq!
nginx -t
systemctl restart nginx
cd /usr/local/nginx/html
mkdir test2
cd /usr/local/nginx/html/test2
echo789> index.html
页面访问
192.168.100.11/test1
# 访问结果为500
此时再打开一台192.168.100.11的shell终端
[root@localhost opt]# tail -f /usr/local/nginx/logs/error.log
页面继续访问 192.168.100.11/test1
xshell报错中出现以下一句话:rewrite or internal redirection cycle while processing
解释:
# 表示在重定向的过程中,使用了last方式进行重定向,但是,没有结束语,陷入了死循环,nginx会自动循环10次,last匹配最多只能执行10次,超过10次没有结束,就会停止,然后报错500。
7.2 基于域名进行跳转,老的不用了的域名,但是依然可以访问,统统跳转到新的域名
vim /usr/local/nginx/conf/nginx.conf
在server模块修改,修改如下
# 修改 server_name如下
server_name www.xy102.com;# 取消charset koi8-r;的注释,修改如下
charset ulf-8;
location / {
root html;if($host='www.xy102.com'){
rewrite ^/(.*)$ http://www.xiaodai.com/$1 permanent;}
index index.html;}
wq!
nginx -t
systemctl restart nginx
做域名映射
vim /etc/hosts
192.168.100.11 www.xy102.com www.xiaodai.com
wq!# 访问www.xy102.com/index.html就是访问www.xiaodai.com/index.htmlcd /usr/local/nginx/html
echo"this is new page"> index.html
页面访问(在虚拟机)
www.xy102.com
# 打印结果为 this is new page 网页地址跳转www.xiaodai.com
7.3 基于客户端的ip进行跳转,公司有新业务上线,测试阶段,其他ip只能显示维护中,只有192.1168.100.11能正常访问
vim /usr/local/nginx/cong/ngin.conf
在server模块的access_log下添加
set$rewritetrue;# 设置一个变量名,rewrite,值是ture# 来进行判断ip是否是合法ipif($remote_addr="192.168.100.11"){set$rewritefalse;}if($rewrite=true){
rewrite (.+) /error.html;# 重定向,192.168.100.13/error.html}
location = /error.html {
root html;}
wq!
cd /usr/local/nginx/html
echo"网页维护中"> error.html
nginx -t
systemctl restart nginx
页面访问
192.168.100.11 #打印结果为 页面维护中
总结·:
location匹配的优先级
版权归原作者 Jessica小戴 所有, 如有侵权,请联系我们删除。