1.什么是rewrite?
主要实现url地址重写,以及url地址跳转。
就是将用户请求web服务器的URL地址重新修改为其他URL地址的过程。
比如说京东,goole,亚马逊都在使用。
域名 | 重写后域名 | |
---|---|---|
www.z.cn | www.amazon.cn | 亚马逊 |
www.g.cn | www.goole.cn | 谷歌 |
www.360buy.com | www.jd.com | 京东 |
58.com | bj.58.com | 京东 |
2.Rewrite使用场景
1.地址转换,用户访问www.z.cn这个URL时,将其定向至一个新的域名www.amazon.cn
2.协议跳转,将用户通过http的请求协议重新跳转至https协议(实现https主要手段)
3.URL静态化,将动态URL地址显示为静态URL的一种技术。能提高搜索引擎抓取,并且能减少动态URL对外暴露过多的参数。ps:Rewrite会轻微增加服务器负担。
3.nginx-rewrite 重写原理
4.Rewrite重写相关模块。
set 设置变量
if 负责语句中的判断
return 返回返回值或URL
rewrite 重定向URL
1.proxy_pass 添加/
location /user {
proxy_passhttp://user_pool/;
}
用户请求:http://agent.oldxu.com/user
代理接收:http://agent.oldxu.com/user
代理转发后端:http://agent.oldxu.com/<<-- 用户请求的/user 删除了
2.proxy_pass 不添加/
location /user {
proxy_passhttp://user_pool;
}
用户请求:http://agent.oldxu.com/user
代理接收:http://agent.oldxu.com/user
代理转发后端:http://agent.oldxu.com/user
静态化:
wordpress
discuz —> 静态化配置 ( 非常的简单 )
💗参数练习一:需求: 将用户请求url.oldxu.zh—> /code/zh, 将用户请求url.oldxu.jp —> /code/jp
#配置nginx配置文件
[root@web01 conf.d]# cat url.oldxu.com.conf
server {
listen 80;
server_name url.oldxu.zh url.oldxu.jp;
#如果请求的域名携带了zh 变量名随意
if ( $http_host ~* "zh" ) {
set $domain "zh";
}
#如果请求的域名携带了jp
if ( $http_host ~* "jp" ) {
set $domain "jp";
}
root /url/$domain;
location / {
index index.html;
}
}
#配置站点目录
[root@web01 conf.d]# mkdir /url/zh -p
[root@web01 conf.d]# mkdir /url/jp -p
[root@web01 conf.d]# echo "Ch" > /url/zh/index.html
[root@web01 conf.d]# echo "...." > /url/jp/index.html
[root@web01 conf.d]# systemctl restart nginx
#本地hosts劫持:
#浏览器测试:输入url.oldxu.zh和url.oldxu.jp
💗参数练习二:需求: 根据用户浏览器使用的语言,自动判断并跳转到不同的语言站点。
同一个域名url.oldxu.com
中文: /url/zh
English: /url/en
#配置nginx配置文件
server {
listen 80;
server_name url.oldxu.com;
if ( $http_accept_language ~* "zh" ) {
set $doamin "zh";
}
if ( $http_accept_language ~* "en" ) {
set $doamin "en";
}
root /url/$doamin;
location / {
index index.html;
}
}
#配置站点目录
#本地hosts劫持:
#浏览器测试:
a1.首先将谷歌浏览器语言设置为中文访问。
a2.输入域名 url.oldxu.com 跳转到中文界面上
b1.然后将谷歌浏览器语言设置为英语访问。
b2…输入域名 url.oldxu.com 跳转到英文界面上。
💗参数练习三:需求:过滤请求中包含a1=3526的http请求到10.16.3.5的8080端口处理。
#配置nginx配置文件
[root@web01 conf.d]# cat url.oldxu.com.conf
server {
listen 80;
server_name url.oldxu.com;
root /url;
default_type text/html;
if ( $request_uri ~ 'a1=3567' ) {
#if ( $request_uri ~ 'a1=\d{6}' ) {
#proxy_pass[http://10.16.3.5:8080;](http://10.16.3.5:8080;)
return 200 "ok!!";
}
location / {
index index.html;
}
}
#配置站点目录
#本地hosts劫持:
#浏览器测试:
a.输入url.oldxu.com 去站点目录/url下找索引文件index.html
b.请求包含a1=3567uri时,返回200 “ok!!”
5.return三种返回类型
1.返回字符串 显示在浏览器上
return 200 “ok!!”; json
a.配置文件
b.谷歌浏览器测试
2.返回状态码 500 403 404
a.配置文件
b.谷歌浏览器测试
3.返回url地址 跳转到一个新的url地址
a.配置文件
b.谷歌浏览器测试
6.Rewrite URL里语法
1.rewrite重写URL ,或跳转其他URL
#rewrite 表达式可以应用在server,location,if标签下
# 关键字 正则 替代内容 flag标记
Syntax: rewrite regex replacement [flag];
Default: - -
Context:server,location,if
#flag
last #本条规则匹配完成后,继续向下匹配新的location URI规则
break #本条规则匹配完成即终止,不再匹配后面的任何规则
redirect #返回302临时重定向,地址栏会显示跳转后的地址
permanent #返回301永久重定向,地址栏会显示跳转后的地址
💗2.Rewrite的Flag标记,
last和break区别实验:
A.我们没有加flag标记。
1.配置nginx文件
2.配置索引文件
echo “1.html” > /url/1.html
echo “2.html” > /url/2.html
echo “3.html” > /url/3.html
echo “a.html” > /url/a.html
echo “b.html” > /url/b.html
3.我们去通过浏览器访问域名url.oldxu.com/1.html时会返回b.html
B。添加break标记
本条规则匹配完成即终止,不再匹配后面的任何规则
break #本条规则匹配完成即终止,不再匹配后面的任何规则
1.配置nginx文件
2.我们去通过浏览器访问域名url.oldxu.com/1.html时会返回b.html
C。添加last标记
本条规则匹配完成后,继续向下匹配新的location URI规则
last #本条规则匹配完成后,继续向下匹配新的location URI规则
2.我们去通过浏览器访问域名url.oldxu.com/1.html时会返回a.html
D。总结break与last区别说明
break 跳转维护页面
last 伪静态
当rewrite规则遇到break后,本location{}与其他location{}的所有rewrite/return规则都不再执行。
当rewrite规则遇到last后,本lication{}里后续rewrite/return规则不执行,但重写后的url再次从头开始执行所有规则,那个匹配执行那个。
💗3.Rewrite的Flag标记,
redirect与permanent区别实验:
1.redirect(临时重定向)与permanent(永久重定向)区别对比实例。
【root@web01】# cat url.oldxu.con.conf
server {
listen 80;
server_name url.oldxu.com;
root /code;
rewrite ^(.*)$[https://www.xuliangwei.com](https://www.xuliangwei.com)redirect; ===>return 302[http://kt.xuliangwei.com;](http://kt.xuliangwei.com;)
rewrite ^(.*)$[https://www.xuliangwei.com](https://www.xuliangwei.com)permanent;===>return 301[http://kt.xuliangwei.com](http://kt.xuliangwei.com;);
}
2.通过浏览器访问测试,测试redirect与permanent
a1.配置nginx文件
rewrite 302 临时跳转
b1.浏览器展示结果
a2.配置nginx文件
b2.浏览器展示结果
3.redirect与permanent的区别
redirect:临时跳转,状态码302 旧网站无影响,新网站无排名
permanent:永久跳转,状态码301 新跳转网站有排名,旧网站排名清空
4.Rewrite跳转生产实践
💗1.rewrite场景示例需求:根据用户浏览器语言调度到不同的页面
同一个域名url.oldxu.com
中文: /url/zh
English: /url/en
#配置nginx配置文件
server {
listen 80;
server_name url.oldxu.com;
if ( $http_accept_language ~* "zh" ) {
set $doamin "zh";
}
if ( $http_accept_language ~* "en" ) {
set $doamin "en";
}
root /url/$doamin;
location / {
index index.html;
}
}
#配置站点目录
#本地hosts劫持:
#浏览器测试:
a1.首先将谷歌浏览器语言设置为中文访问。
a2.输入域名 url.oldxu.com 跳转到中文界面上
b1.然后将谷歌浏览器语言设置为英语访问。
b2…输入域名 url.oldxu.com 跳转到英文界面上。
💗2.rewrite场景示例需求:用户通过手机设备访问url.oldxu.com,跳转至url.oldxu.com/m
😀情景①url.oldxu.com—>url.oldxu.com/m
#本地nginx配置文件
[root@web01 conf.d]# cat url.oldxu.com.conf
server {
listen 80;
server_name url.oldxu.com;
root /url;
if ( $http_user_agent ~* "android|iphone|ipad" ) {
rewrite ^/$ /m redirect;
}
location / {
index index.html;
}
}
#配置站点目录和索引文件
mkdir /url
echo "welcome to url page" >/url/index.html
mkdir /url/m
echo "m.page" >/url/m/index.html
#谷歌浏览器访问测试
1.模拟pc端访问url.oldxu.com 这是到站点目录/url下寻找索引文件index.html
2.模拟手机端访问url.oldxu.com这个域名,会跳转到url.oldxu.com/m ,并且显示/url/m下的index.html索引文件。
😀情景②url.oldxu.com —> m.oldxu.com
#本地nginx配置文件
[root@web01 conf.d]# cat url.oldxu.com.conf
server {
listen 80;
server_name url.oldxu.com;
root /url;
if ( $http_user_agent ~* "android|iphone|ipad" ) {
rewrite ^/$[http://m.oldxu.com](http://m.oldxu.com)redirect;
}
location / {
index index.html;
}
}
server {
listen 80;
server_name m.oldxu.com;
root /url/m;
location / {
index index.html;
}
}
#谷歌浏览器测试
1.模拟pc端访问url.oldxu.com 这是到站点目录/url下寻找索引文件index.html
2.模拟手机端访问url.oldxu.com这个域名,会跳转到新的URL m.oldxu.com,并且显示/url/m下的index.html索引文件。
7.rewrite几个比较重要的场景!!!
💗场景一:需求: 用户通过http协议请求,能自动跳转至https协议。
1.首先我们没有证书所以我们在做http访问到https这个实验时,可以跳转到https但是却不能访问。所以我们用curl -I 进行测试
2.我们给本地虚拟机/etc/hosts 写入 10.0.0.7 url.oldxu.com 配置本地虚拟机hosts劫持
#配置nginx配置文件,有两种写法满足http请求跳到https
第一种是 rewrite ^(.*)$[https://$http_host$1](https://$http_host$1)redirect;
第二种是
return 302[https://$http_host$request_uri;](https://$http_host$request_uri;)
#第一种写法nginx配置:
[root@web01 conf.d]# cat url.oldxu.com.conf
server {
listen 80;
server_name url.oldxu.com;
rewrite ^(.*)$[https://$http_host$1](https://$http_host$1)redirect;
}
#curl -I 测试
[root@web01 conf.d]# curl -Ihttp://url.oldxu.com
第二种写法nginx配置:
[root@web01 conf.d]# cat url.oldxu.com.conf
server {
listen 80;
server_name url.oldxu.com;
return 302https:// h t t p h o s t http_host httphostrequest_uri;
}
#curl -I 测试
[root@web01 conf.d]# curl -Ihttp://url.oldxu.com/test1232432543.html
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eSVS9eNl-1604390984308)(https://uploader.shimo.im/f/GUDPyQjCfOA8vfgh.png!thumbnail)]
💗场景二:需求: 网站在维护过程中,希望用户访问所有网站重定向至一个维护页面。
#实验理论与准备
1.所有网站是指有很多location,所以这里我们要用到break (Rewrite的flag标记),跳到维护界面后终止向下对location的匹配。
2.准备一个维护界面的图片(wh.png),当然也可以是代码。
#配置nginx的配置文件
[root@web01 conf.d]# cat url.oldxu.com.conf
server {
listen 80;
server_name url.oldxu.com;
root /code;
rewrite ^(.*)$ /wh.png break;
location / {
index index.html;
}
location /admin {
proxy_pass[http://127.0.0.1:9000;](http://127.0.0.1:9000;)
}
}
#配置维护页面的站点目录(/code/)和索引文件。
#谷歌浏览器访问测试url.oldxu.com能否跳转到维护页面。
💗场景三:需求: 公司网站在停机维护时,指定的IP能够正常访问,其他的IP跳转到维护页
10.0.0.1 内部服务器 --> 成功
10.0.0.100 正常用户 --> 失败
#配置nginx配置文件
[root@web01 conf.d]# cat url.oldxu.com.conf
server {
listen 80;
server_name url.oldxu.com;
root /url;
#初始值为0
set $ip 0;
#如果是内部IP,则为1
if ( $remote_addr ~ "10.0.0.1" ) {
set $ip 1;
}
#判断ip变量如果为0则跳转,不为0则不跳转.
if ( $ip = "0" ) {
rewrite ^(.*)$ /wh.png break;
}
location / {
index index.html;
}
location /admin {
proxy_pass[http://127.0.0.1:9000;](http://127.0.0.1:9000;)
}
}