1.概述
rewrite 和 location 相似,用于实现跳转,主要区别在于 rewrite
是在同一域名内更改获取资源的路径,而location是一对路径做控制访问或反向代理
2.常见的Nginx正则表达式
^ :匹配输入字符串的起始位置
$ :匹配输入字符串的结束位置
- :匹配前面的字符零次或多次。如“ol*”能匹配“o”及“ol”、“oll”
- :匹配前面的字符一次或多次。如“ol+”能匹配“ol”及“oll”、“olll”,但不能匹配“o”
? :匹配前面的字符零次或一次,例如“do(es)?”能匹配“do”或者“does”,”?”等效于”{0,1}”
. :匹配除“\n”之外的任何单个字符,若要匹配包括“\n”在内的任意字符,请使用诸如“[.\n]”之类的模式
\ :将后面接着的字符标记为一个特殊字符或一个原义字符或一个向后引用。如“\n”匹配一个换行符,而“$”则匹配“$”
\d :匹配纯数字
{n} :重复 n 次
{n,} :重复 n 次或更多次
{n,m} :重复 n 到 m 次
[] :定义匹配的字符范围
[c] :匹配单个字符 c
[a-z] :匹配 a-z 小写字母的任意一个
[a-zA-Z0-9] :匹配所有大小写字母或数字
() :表达式的开始和结束位置
| :或运算符
3.location
3.1 location大致可以分为三类
精准匹配:location = / {}
一般匹配:location / {}
正则匹配:location ~ / {}
3.2 location常用的匹配规则
符号 | 描述 |
---|---|
= | 进行普通字符精准匹配,也就是完全匹配 |
^~ | 表示普通字符匹配,使用前缀匹配;如果匹配成功,则不再匹配后续location |
~ | 区分大小写的匹配 |
~* | 不区分大小写的匹配 |
!~ | 区分大小写的匹配取非 |
!~* | 不区分大小写的匹配取非 |
3.3 location 说明
localtion = / {}
=为精准匹配 /,主机名后面不能带任何字符串,比如访问 / 和 /xcf,则 / 匹配,/xcf 不匹配
location / {}
因为所有的地址都以 / 开头,所以这条规则将匹配到所有的请求,比如访问 / 和 /data,则 / 匹配,/data也匹配
但若后面是正则表达式,则会和最长字符串优先匹配(最长匹配)
location /documents/ {}
匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索其它 location
location /documents/abc {}
匹配任何以 /documents/abc 开头的地址,匹配符合后,还要继续往下搜索其他 location
只有其他 location 后面的正则表达式没有匹配到时,才会采用这一条
location ^~ /images/ {}
匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,并采用这条
location ~ .(gif|jpg|jpeg)$ {}*
匹配所有以 gif、jpg、jpeg 为结尾的请求
然而,所有请求 /images/ 下的图片会被 location ^~ /images/ 处理,因为 ^~ 的优先级更高,所以到达不了这一条正则
location /images/abc {}
最长字符匹配到 /images/abc,优先级最低,继续往下搜索其它 location,会发现 ^~ 和 ~ 存在
location ~ /images/abc {}
匹配以 /images/abc 开头的,优先级次之,只有去掉 location ^~ /images 才会采用这一条
location /images/abc/1.html {}
匹配 /images/abc/1.html 文件,如果和正则 ~ /images/abc/1.html 相比,正则优先级更高
优先级总结:
(location = 精准路径) > (location ^~ 前缀路径) > (location ~* 正则顺序) > (location 最长不带修饰符的一般匹配) > (location / 通用匹配)
4.匹配规则定义
4.1 第一个必选的规则
location / {
root html;
index index.html index.htm;
}
4.2 第二个必选的规则 处理静态文件请求 目录匹配 后缀匹配
location ^~ /static/ {
root /static/;
}
location ~* .(jpg|gif|swf)$ {
root /images/;
}
4.3 第三个规则[通用规则] 比如用于转发php、jsp的动态请求至后端应用服务器
location / {
proxy_pass http://tomcat_server;
}
5.rewrite功能
为Nginx提供全局变量或主机设置的变量,并结合正则表达式和标记位实现URL重写以及重定向
rewrite只能放在server{},location,if{}中默认值对域名后边的除去传递的参数外的字符串起作用
http://www.benet.com/images/index.php?id=1&u=str
port请求的方法不安全会暴露请求的参数[?id=1&u=str]
只对/images/index.php进行重写
使用ngx_http_rewrite_module模块[默认自带]
支持if语句不自持else,可以循环执行10次,超出返回500错误
支持pero正则表达式
6.rewrite的执行顺序
先执行Server块里的rewite指令
执行location匹配
执行选定的location中的rewite指令
语法格式:rewrite <规则> <跳转后的内容>
6.1 flag说明
last 规则匹配完成后会继续向下匹配新的location URL规则[一般用于server和if中]
break 规则匹配完成即终止,不在匹配后面的任何规则[一般用于location中]
redirect 返回302临时重定向,浏览器会显示跳转后的URL地址
permanent 返回301永久重定向,浏览器会显示跳转后的URL地址
7.基于域名的跳转
vim /usr/local/nginx/conf/nginx.conf
server {
listen 80;
server_name www.benet.com;
#修改域名
charset utf-8;
access_log /var/log/nginx/www.benet.com-access.log;
#日志保存路径修改
location / {
if ($host = ‘www.benet.com‘) {
#$host为rewrite全局变量,代表请求主机头字段或主机名
rewrite ^/(.*)$ http://www.accp.com/$1 permanent;
#$1为正则匹配得内容,即域名后边得字符串
}
root html;
index index.html index.htm;
}
echo "192.168.1.1 www.benet.com www.accp.com" >> /etc/hosts
systemctl restart nginx.service
8.基于客户端IP地址进行重写跳转
set $rewrite true;
if ($remote_addr = "192.168.1.1"){
set $rewrite false;
}
if ($rewrite = true) {
rewrite (.+) /error.png
}
localtion ~ /index.html{
root /var/www/html;
}
9.基于参数匹配的跳转
server {
listen 80;
server_name www.benet.com;
access_log /var/log/nginx/www.benet.com-access.log;
if ($request_uri ~ ^/100-(100|200)-(\d+)\.html$) {
#设置正则匹配
rewrite (.*) http://www.benet.com permanent;
#设置重写
}
location / {
root html;
index index.html index.htm;
}
systemctl restart nginx.service
10.基于旧域名跳转到新域名后并加目录
server {
listen 80;
server_name www.benet.com;
location /post {
rewrite (.+) http://www.accp.com/bbs$1 permanent;
#这里$1为位置变量,代表/post
}
location / {
root html;
index index.html index.htm;
}
mkdir -p /usr/local/nginx/html/bbs/post
echo "Hello World" >> /usr/local/nginx/html/bbs/post/index.html
echo "192.168.1.1 www.accp.com" >> /etc/hosts
systemctl restart nginx.service
11.基于某结尾的文件跳转
location ~* ..jpg {
rewrite (.) http://www.benet.com permanent;
}