Rewrite基本概述
什么是rewrite
Rewrite主要实现url地址重写,以及重定向,就是把传入web的请求重定向到其他url的过程。
Rewrite使用场景
1、地址跳转,用户访问www.lzy.com这个URL是,将其定向至一个新的域名mobile.lzy.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区别对比示例
[root@web01 conf.d]# cat nginx.conf
server {
listen 80;
server_name test.ahui.com;
root /code/test/;
location / {
rewrite /1.html /2.html;
rewrite /2.html /3.html;
}
location /2.html {
rewrite /2.html /a.html;
}
location /3.html {
rewrite /3.html /b.html;
}
}
修改为break和last进行测试
last: 本条规则匹配后停止向后匹配 携带URL 重新向域名发起请求
访问的是1.html 则跳转到2.html 停止向后匹配 重新携带2.html 发起请求
rewrite.ahui.com/2.tml 重新请求后的结果 会继续跳转
break: 本条规则匹配后停止向后匹配 不在重新发起新的请求
请求的是 rewrite.ahui.com/1.html 跳转到2.html 有个flag break
则停止匹配 停止重新发起请求: 响应的是2.html里的内容
redirect与permanent区别对比示例
[root@web01 conf.d]# cat rewrite.conf
server {
listen 80;
server_name rewrite.lzy.com;
root /code;
location /test {
rewrite ^(.*)$ http://www.ahui.com redirect;
#rewrite ^(.*)$ http://www.ahui.com permanent;
#return 301 http://www.ahui.com;
#return 302 http://www.ahui.com;
}
}
redirect与permanent区别
redirect: 每次请求都会询问服务器,如果当服务器不可用时,则会跳转失败。
permanent: 第一次请求会询问,浏览器会记录跳转的地址,第二次则不再询问服务器,直接通过浏览器缓存的地址跳转。
Rewrite规则实践
在写rewrite规则之前,我们需要开启rewrite日志对规则的匹配进行调试。
[root@web01 code]# vim /etc/nginx/nginx.conf
/var/log/nginx/error.log notice;
http{
rewrite_log on;
}
案例一
用户访问/abc/1.html实际上真实访问的是/ccc/bbb/2.html
http://www.ahui.com/abc/1.html ==> http://www.ahui.com/ccc/bbb/2.html
准备真实访问路径
[root@web03 ~]# mkdir /code/ccc/bbb -p
[root@web03 ~]# echo "ccc_bbb_2" > /code/ccc/bbb/2.html
2.Nginx跳转配置
[root@web03 ~]# cd /etc/nginx/conf.d/
[root@web03 conf.d]# cat ccbb.conf
server {
listen 80;
location / {
root /code;
index index.html;
}
location /abc {
rewrite (.*) /ccc/bbb/2.html redirect;
#return 302 /ccc/bbb/2.html;
}
}
3.重启Nginx服务
[root@web03 conf.d]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@web03 conf.d]# nginx -s reload
案例二
用户访问/2018/ccc/2.html实际上真实访问的是/2014/ccc/bbb/2.html
http://www.ahui.com/2018/ccc/2.html ==> http://www.ahui.com/2014/ccc/bbb/2.html
1.准备真是的访问路径
[root@web03 conf.c]# mkdir /code/2014/ccc/bbb -p
[root@web03 conf.c]# echo "2014_ccc_bbb_2" > /code/2014/ccc/bbb/2.html
2.Nginx跳转配置
[root@web03 conf.d]# cat ccbb.conf
server {
listen 80;
location / {
root /code;
index index.html;
}
location /2018 {
rewrite ^/2018/(.*)$ /2014/$1 redirect;
}
}
3.重启nginx服务
[root@web03 conf.d]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@web03 conf.d]# nginx -s reload
案例三
用户访问/test实际上真实访问的是https://www.ahui.com
1.Nginx跳转配置
[root@web03 conf.d]# cat test.conf
server {
listen 80;
location /test {
rewrite (.*) https://www.ahui.com redirect;
}
}
2.重启nginx服务
[root@web03 conf.d]# nginx -s reload
案例四
用户访问couese-11-22-33.html实际上真实访问的是/course/11/22/33/course_33.html
http://www.ahui.com/couese-11-22-33.html ==> http://www.ahui.com/course/11/22/33/course_33.html
1.准备真实的访问路径
[root@web03 ~]# mkdir /code/course/11/22/33 -p
[root@web03 ~]# echo "curl docs.etiantian.org" > /code/course/11/22/33/course_33.html
2.Nginx跳转配置
[root@web03 conf.d]# cat test.conf
server {
listen 80;
root /code;
index index.html;
location / {
#灵活配法
rewrite ^/course-(.*)-(.*)-(.*).html$ /course/$1/$2/$3/course_$3.html redirect;
#固定配法
#rewrite ^/course-(.*) /course/11/22/33/course_33.html redirect;
}
}
3.重启nginx服务
[root@web03 conf.d]# nginx -s reload
案例五
将http请求跳转到https
Nginx跳转配置
server {
listen 80;
server_name www.ahui.com;
rewrite ^(.*) https://$server_name$1 redirect;
#return 302 https://$server_name$request_uri;
}
server {
listen 443;
server_name www.ahui.com;
ssl on;
}
错误页跳转
server {
listen 80;
root /code;
location /test {
rewrite (.*) https://www.ahui.com redirect;
}
error_page 403 404 500 501 502 @error_test;
location @error_test {
rewrite ^(.*)$ /404.html break;
}
}