首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ngx_http_rewrite_module

  • 指令
  • break
  • if
  • return
  • rewrite
  • rewrite_log
  • set
  • uninitialized_variable_warn
  • 内部实施

ngx_http_rewrite_module模块用于使用PCRE正则表达式更改请求URI,返回重定向并有条件地选择配置。

break,if,return,rewrite和set指令按以下顺序处理:

  • 在服务器级指定的该模块的指令是按顺序执行的;
  • 反复:
    • 基于请求URI来搜索位置;
    • 在找到的位置内指定的该模块的指令是按顺序执行的;
    • 如果请求URI被重写,则重复循环但不超过10次。

指令

句法:

break;

默认:

语境:

服务器,位置,if

停止处理当前的一组ngx_http_rewrite_module指令。

如果在位置内指定了指令,则在该位置继续处理请求。

例:

代码语言:javascript
复制
if ($slow) {
    limit_rate 10k;
    break;
}

句法:

if(condition){...}

默认:

语境:

服务器,位置

指定condition的评估。如果为true,则在花括号内指定的模块指令被执行,并且该请求被分配if指令内的配置。if指令内的配置从先前的配置级别继承。

条件可能是以下任何一种情况:

  • 变量名称; 如果变量的值是空字符串或“ 0”,则为false ; 在版本1.0.1之前,任何以“ 0” 开头的字符串都被认为是错误的值。
  • 使用“ =”和“ !=”运算符比较变量和字符串;
  • 使用“ ~”(区分大小写的匹配)和“ ~*”(区分大小写的匹配)运算符将变量与正则表达式匹配。正则表达式可以包含可供稍后在$1.. $9变量中重用的捕获。负运营商“ !~”和“ !~*”也是可用的。如果正则表达式包含“ }”或“ ;”字符,则整个表达式应该用单引号或双引号括起来。
  • 用“ -f”和“ !-f”操作符检查文件是否存在;
  • 用“ -d”和“ !-d”运算符检查目录是否存在;
  • 使用“ -e”和“ !-e”运算符检查文件,目录或符号链接的存在性;
  • 使用“ -x”和“ !-x”运算符检查可执行文件。

例子:

代码语言:javascript
复制
if ($http_user_agent ~ MSIE) {
    rewrite ^(.*)$ /msie/$1 break;
}

if ($http_cookie ~* "id=([^;]+)(?:;|$)") {
    set $id $1;
}

if ($request_method = POST) {
    return 405;
}

if ($slow) {
    limit_rate 10k;
}

if ($invalid_referer) {
    return 403;
}

$ invalid_referer嵌入式变量的值由valid_referers指令设置。

句法:

返回代码文本;返回码URL;返回URL;

默认:

语境:

服务器,位置,if

停止处理并将指定的内容返回code给客户端。非标准代码444在不发送响应报头的情况下关闭连接。

从版本0.8.42开始,可以指定重定向URL(对于代码301,302,303,307和308)或响应主体text(对于其他代码)。响应正文文本和重定向URL可以包含变量。作为特殊情况,可以将重定向URL指定为此服务器本地的URI,在这种情况下,完整重定向URL根据请求方案($scheme)和server_name_in_redirect和port_in_redirect指令形成。

另外,URL可以将具有代码302的临时重定向指定为唯一参数。这样的参数应该以“ http://”,“ https://”或“ $scheme”字符串开头。一个URL可以包含变量。

在版本0.7.51之前仅可以返回以下代码:204,400,402-406,408,410,411,413,416和500-504。代码307不被视为重定向直到版本1.1.16和1.0.13。代码308在版本1.13.0之前不被视为重定向。

另请参阅error_page指令。

句法:

重写正则表达式替换标志;

默认:

语境:

服务器,位置,if

如果指定的正则表达式与请求URI匹配,则URI将按replacement字符串中指定的方式更改。这些rewrite指令按照其在配置文件中的顺序依次执行。可以使用标志来终止对指令的进一步处理。如果替换字符串以“ http://”,“ https://”或“ $scheme” 开头,则处理停止并且重定向返回给客户端。

可选flag参数可以是以下之一:

last停止处理当前的ngx_http_rewrite_module指令集并开始搜索匹配改变的URI的新位置; 像break指令一样break停止处理当前的一组ngx_http_rewrite_module指令; redirect返回302代码的临时重定向; 如果替换字符串不以“ http://”,“ https://”或“ $scheme” 开头,则使用该字符串; permanent返回301代码的永久重定向。

完整的重定向URL根据请求方案($scheme)和server_name_in_redirect和port_in_redirect指令形成。

例:

代码语言:javascript
复制
server {
    ...
    rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$2.mp3 last;
    rewrite ^(/download/.*)/audio/(.*)\..*$ $1/mp3/$2.ra  last;
    return  403;
    ...
}

但是,如果这些指令放在“ /download/”位置内,那么该last标志应该被替换break,否则nginx会做10个周期并返回500错误:

代码语言:javascript
复制
location /download/ {
    rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$2.mp3 break;
    rewrite ^(/download/.*)/audio/(.*)\..*$ $1/mp3/$2.ra  break;
    return  403;
}

如果一个replacement字符串包含新的请求参数,那么之前的请求参数将被追加。如果这是不希望的,那么在替换字符串的末尾添加一个问号可以避免添加它们,例如:

代码语言:javascript
复制
rewrite ^/users/(.*)$ /show?user=$1? last;

如果正则表达式包含“ }”或“ ;”字符,则整个表达式应该用单引号或双引号括起来。

句法:

rewrite_log 开启| 关闭;

默认:

rewrite_log 关闭;

语境:

http,服务器,位置,if

启用或禁用将ngx_http_rewrite_module模块指令处理结果记录到notice级别的error_log中。

句法:

设置$ variable值;

默认:

语境:

服务器,位置,if

value为指定的设置一个variable。该value可以包含文本,变量,他们的组合。

句法:

uninitialized_variable_warn 开启 | 关闭;

默认:

uninitialized_variable_warn on;

语境:

http,服务器,位置,if

控制是否记录有关未初始化变量的警告。

内部实施

ngx_http_rewrite_module模块指令是在配置阶段编译成被请求处理过程中解释内部指示。解释器是一个简单的虚拟堆栈机器。

例如,指令

代码语言:javascript
复制
location /download/ {
    if ($forbidden) {
        return 403;
    }

    if ($slow) {
        limit_rate 10k;
    }

    rewrite ^/(download/.*)/media/(.*)\..*$ /$1/mp3/$2.mp3 break;
}

将被翻译成这些说明:

代码语言:javascript
复制
variable $forbidden
check against zero
    return 403
    end of code
variable $slow
check against zero
match of regular expression
copy "/"
copy $1
copy "/mp3/"
copy $2
copy ".mp3"
end of regular expression
end of code

请注意,上面的limit_rate指令没有说明,因为它与ngx_http_rewrite_module模块无关。为if块创建一个单独的配置。如果条件成立,则将该配置分配给limit_rate等于10k 的请求。

指令

代码语言:javascript
复制
rewrite ^/(download/.*)/media/(.*)\..*$ /$1/mp3/$2.mp3 break;

如果正则表达式中的第一个斜杠放在括号内,可以通过一条指令缩小:

代码语言:javascript
复制
rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$2.mp3 break;

相应的说明将如下所示:

代码语言:javascript
复制
match of regular expression
copy $1
copy "/mp3/"
copy $2
copy ".mp3"
end of regular expression
end of code

扫码关注腾讯云开发者

领取腾讯云代金券