1.开启rewrite日志
rewrite_log on; #http 段加入
error_log logs/xxxerror.log notice; #在将错误日志级别调低
2.跳转域名
location / {
rewrite / https://www.baidu.com;
}
#表示,只要访问这个域名直接跳转到 baidu
#查看日志能看到记录用"/"访问了"111.com",跳转到了"baidu"
修改下代码
location /rewrite/ {
rewrite / https://www.baidu.com;
}
#表示只有用域名后面跟着"/rewrite/",文件夹才会跳转(只有/rewrite/才会触发跳转,其他文件夹正常转发)
如下图
#我这边用"www.111.com/rewrite/123.com" 访问才跳转了
3.使用正则跳转
例子1,
www.111.com/111/index.html 跳转到 www.111.com/222/index.html
location / {
rewrite ^/111/(.*)$ /222/$1 ;
}
#"^"表示根的意思,就表示 www.111.com 的的意思,(.*) 匹配所有的意思,后面"$1"调用,
#日志,能就看出/111/index.html 跳转到 /222/index.html
4.rewrite指令
last 终止在本location块中处理接收到的URI,并将此处重写的URI作为新的URI使用其他location进行处理,(转到第1个location 匹配)
break 将此处重写的URI作为一个新的URI在当前location中继续执行,并不会将新的URI转向其他location。(继续从当前的location 继续往下匹配)
redirect 将重写后的URI返回个客户端,状态码是302,表明临时重定向,主要用在replacement字符串不以“http://”,“ https://”或“ $scheme” 开头;
permanent 将重写的URI返回客户端,状态码为301,指明是永久重定向;
那么什么是永久性跳转,什么是临时跳转,这有什么作用呢?下面我们举例说明:
如果有一个url,/a。
如果配置成
rewrite "/a" "http://test.html" redirect;
则说明这个跳转是一个临时跳转,此时如果有网络爬虫爬这个链接时,是不会更新自己的url数据库的。
但是如果配置成permanet,则爬虫会更新自己的url数据库,把/a更新为http://test.html。
这也就是临时跳转和永久跳转的区别。
break和last区别测试
location /222/ {
rewrite ^/222/(.*) /333/$1;
}
location / {
rewrite ^/111/(.*) /222/$1 break;
}
#上面配置,最后url会输出到"222"文件夹里,如果把break 换成了last的话,url里的111会被替换成222 从第一个location继续匹配,这样最终输出url是"333"
#
5.if 判断加调用变量跳转
实例1
if ($server_port = 80) {
rewrite ^(.*)$ https://$host$1 permanent;
}
#在http段配置,表示如果访问者是以80端口访问的,就执行跳转。匹配根后面的url,重写成https://"访问的域名"+"匹配的url"
实例2
if ( !-f $request_filename ){
rewrite (.*) http://$host/bucunzai.html;
}
#在location 段配置,"! -f $request_filename" 表示,检测url请求本地是否有问题,如果页面文件不存在,就转发给 "buzunzai.html".
实例3 www.111.com/jpg-aaa-bbb-ccc.html => www.111.com/jpg/aaa/bbb/ccc/jpg_ccc.html
location / {
rewrite ^/(.*)-(.*)-(.*)-(.*).html$ /$1/$2/$3/$4/$1_$4.html ;
}
实例4 补全www
if ($host = "111.com"){
rewrite ^(.*)$ http://www.111.com$1 last;
}
#写在http段,"$host" 变量就是 url里的域名假如以 "111.com/123.html" 访问就是
"111.com",假如以 "www.111.com/233.html" 就是"www.111.com"