rewrite重写概述
Rewrite主要实现url地址重写,以及重定向,就是把传入web的请求重定向到其他url的过程。
rewrite重写使用场景
1、地址跳转,用户访问www.test.com这个URL时,将其定向至一个新的域名mobile.test.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区别对比示例
vim nginx.conf
server {
listen 80;
server_name rewrite.test.com;
root /code/test/;
location / {
rewrite /1.html /2.html;
#rewrite /1.html /2.html last; last表示匹配到这个规则后,当前location里的规则就不匹配了
#rewrite /1.html /2.html break; break表示就匹配到当前,后面的所有规则都不进行匹配
rewrite /2.html /3.html;
}
location /2.html {
rewrite /2.html /a.html;
}
location /3.html {
rewrite /3.html /b.html;
}
}redirect和permanent区别对比
redirect(302): 每次请求都会询问服务器,如果当服务器不可用时,则会跳转失败。
permanent(301): 第一次请求会询问,浏览器会记录跳转的地址,第二次则不再询问服务器,直接通过浏览器缓存的地址跳转。
server {
listen 80;
server_name rewrite.test.com;
root /code;
location /test {
rewrite ^(.*)$ http://xwutx.cn redirect;
#rewrite ^(.*)$ http://xwutx.cn permanent;
#return 301 http://xwutx.cn;
#return 302 http://xwutx.cn;
}
}对比结果


案例一
用户访问/abc/1.html实际上真实访问的是/ccc/bbb/2.html
#http://www.test.com/abc/1.html ==> http://www.test.com/ccc/bbb/2.html
#1.准备真实访问路径
mkdir /code/ccc/bbb -p
echo "ccc_bbb_2" > /code/ccc/bbb/2.html
#2.Nginx跳转配置
cd /etc/nginx/conf.d/
vim ccbb.conf
server {
listen 80;
server_name www.test.com;
location / {
root /code;
index index.html;
}
location /abc {
rewrite (.*) /ccc/bbb/2.html redirect;
#return 302 /ccc/bbb/2.html;
}
}
#3.重启Nginx服务
nginx -t
#nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
#nginx: configuration file /etc/nginx/nginx.conf test is successful
nginx -s reload案例二
用户用户访问/test实际上真实访问的是https://www.xwutx.cn
#1.Nginx跳转配置
[root@web03 conf.d]# cat test.conf
server {
listen 80;
location /test {
rewrite (.*) https://www.xwutx.cn redirect;
}
}
#2.重启nginx服务
[root@web03 conf.d]# nginx -s reload案例三
将http请求跳转到https
#Nginx跳转配置
server {
listen 80;
server_name www.test.com;
rewrite ^(.*) https://$server_name$1 redirect;
#return 302 https://$server_name$request_uri;
}
server {
listen 443 ssl;
server_name www.xwutx.cn;
}
#变量使用
#案例1:需要在跳转后的请求行加上想要的参数&showoffline=1
server {
listen 80;
server_name www.test.com;
# $args为Nginx内置变量请求行的参数
set $args "&showoffline=1";
location / {
root /code;
index index.html;
}
if ($remote_addr = 10.0.0.1 ){
rewrite (.*) http://www.test.com$1;
}
}
#案例2:网站维护,指定IP正常访问,其他IP跳转维护页面
server {
listen 80;
server_name www.test.com;
root /code;
charset utf-8,gbk;
location / {
index index.html;
set $ip 0; # 设置变量为0
if ($remote_addr = "10.0.0.1"){
set $ip 1; # 如果来源IP为0.1则设置为1
}
if ($ip = 0){ # 判断如果变量为0 则跳转维护页面
rewirte ^(.*)$ /wh.html break;
}
}
}
Nginx内置参数
$args #这个变量等于请求行中的参数。
$content_length #请求头中的Content-length字段。
$content_type #请求头中的Content-Type字段。
$document_root #当前请求在root指令中指定的值。
$host #请求主机头字段,否则为服务器名称。
$http_user_agent #客户端agent信息
$http_cookie #客户端cookie信息
$limit_rate #这个变量可以限制连接速率。
$request_body_file #客户端请求主体信息的临时文件名。
$request_method #客户端请求的动作,通常为GET或POST。
$remote_addr #客户端的IP地址。
$remote_port #客户端的端口。
$remote_user #已经经过Auth Basic Module验证的用户名。
$request_filename #当前请求的文件路径,由root或alias指令与URI请求生成。
$query_string #与$args相同。
$scheme #HTTP方法(如http,https)。
$server_protocol #请求使用的协议,通常是HTTP/1.0或HTTP/1.1。
$server_addr #服务器地址,在完成一次系统调用后可以确定这个值。
$server_name #服务器名称。
$server_port #请求到达服务器的端口号。
$request_uri #包含请求参数的原始URI,不包含主机名,如:”/foo/bar.php?arg=baz”。
$uri #不带请求参数的当前URI,$uri不包含主机名,如”/foo/bar.html”。
$document_uri #与$uri相同。
$X-Forwarded-For:HTTP的请求端真实的IP,只有在通过了HTTP 代理或者负载均衡服务器时才会添加该项。标准格式如下:X-Forwarded-For: client1, proxy1, proxy2
评论区