Module ngx_http_rewrite_module
http://nginx.org/en/docs/http/ngx_http_rewrite_module.html
| Directives break if return rewrite rewrite_log set uninitialized_variable_warn Internal Implementation | 
The ngx_http_rewrite_module module is used to change request URI using PCRE regular expressions, return redirects, and conditionally select configurations.
The break, if, return, rewrite, and set directives are processed in the following order:
- the directives of this module specified on the server level are executed sequentially;
- repeatedly:
Directives
| Syntax: | break; | 
|---|---|
| Default: | — | 
| Context: | server,location,if | 
Stops processing the current set of ngx_http_rewrite_module directives.
If a directive is specified inside the location, further processing of the request continues in this location.
Example:
if ($slow) {
    limit_rate 10k;
    break;
}
| Syntax: | if ( | 
|---|---|
| Default: | — | 
| Context: | server,location | 
The specified condition is evaluated. If true, this module directives specified inside the braces are executed, and the request is assigned the configuration inside the if directive. Configurations inside the if directives are inherited from the previous configuration level.
A condition may be any of the following:
- a variable name; false if the value of a variable is an empty string or “0”;Before version 1.0.1, any string starting with “ 0” was considered a false value.
- comparison of a variable with a string using the “=” and “!=” operators;
- matching of a variable against a regular expression using the “~” (for case-sensitive matching) and “~*” (for case-insensitive matching) operators. Regular expressions can contain captures that are made available for later reuse in the$1..$9variables. Negative operators “!~” and “!~*” are also available. If a regular expression includes the “}” or “;” characters, the whole expressions should be enclosed in single or double quotes.
- checking of a file existence with the “-f” and “!-f” operators;
- checking of a directory existence with the “-d” and “!-d” operators;
- checking of a file, directory, or symbolic link existence with the “-e” and “!-e” operators;
- checking for an executable file with the “-x” and “!-x” operators.
Examples:
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;
}
A value of the
$invalid_refererembedded variable is set by the valid_referers directive.
| Syntax: | return return return  | 
|---|---|
| Default: | — | 
| Context: | server,location,if | 
Stops processing and returns the specified code to a client. The non-standard code 444 closes a connection without sending a response header.
Starting from version 0.8.42, it is possible to specify either a redirect URL (for codes 301, 302, 303, 307, and 308) or the response body text (for other codes). A response body text and redirect URL can contain variables. As a special case, a redirect URL can be specified as a URI local to this server, in which case the full redirect URL is formed according to the request scheme ($scheme) and theserver_name_in_redirect and port_in_redirect directives.
In addition, a URL for temporary redirect with the code 302 can be specified as the sole parameter. Such a parameter should start with the “http://”, “https://”, or “$scheme” string. A URL can contain variables.
Only the following codes could be returned before version 0.7.51: 204, 400, 402 — 406, 408, 410, 411, 413, 416, and 500 — 504.
The code 307 was not treated as a redirect until versions 1.1.16 and 1.0.13.
The code 308 was not treated as a redirect until version 1.13.0.
See also the error_page directive.
| Syntax: | rewrite  | 
|---|---|
| Default: | — | 
| Context: | server,location,if | 
If the specified regular expression matches a request URI, URI is changed as specified in the replacementstring. The rewrite directives are executed sequentially in order of their appearance in the configuration file. It is possible to terminate further processing of the directives using flags. If a replacement string starts with “http://”, “https://”, or “$scheme”, the processing stops and the redirect is returned to a client.
An optional flag parameter can be one of:
- last
- stops processing the current set of ngx_http_rewrite_moduledirectives and starts a search for a new location matching the changed URI;
- break
- stops processing the current set of ngx_http_rewrite_moduledirectives as with the break directive;
- redirect
- returns a temporary redirect with the 302 code; used if a replacement string does not start with “http://”, “https://”, or “$scheme”;
- permanent
- returns a permanent redirect with the 301 code.
The full redirect URL is formed according to the request scheme ($scheme) and theserver_name_in_redirect and port_in_redirect directives.
Example:
server {
    ...
    rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$2.mp3 last;
    rewrite ^(/download/.*)/audio/(.*)\..*$ $1/mp3/$2.ra  last;
    return  403;
    ...
}
But if these directives are put inside the “/download/” location, the last flag should be replaced bybreak, or otherwise nginx will make 10 cycles and return the 500 error:
location /download/ {
    rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$2.mp3 break;
    rewrite ^(/download/.*)/audio/(.*)\..*$ $1/mp3/$2.ra  break;
    return  403;
}
If a replacement string includes the new request arguments, the previous request arguments are appended after them. If this is undesired, putting a question mark at the end of a replacement string avoids having them appended, for example:
rewrite ^/users/(.*)$ /show?user=$1? last;
If a regular expression includes the “}” or “;” characters, the whole expressions should be enclosed in single or double quotes.
| Syntax: | rewrite_log  | 
|---|---|
| Default: | rewrite_log off; | 
| Context: | http,server,location,if | 
Enables or disables logging of ngx_http_rewrite_module module directives processing results into the error_log at the notice level.
| Syntax: | set  | 
|---|---|
| Default: | — | 
| Context: | server,location,if | 
Sets a value for the specified variable. The value can contain text, variables, and their combination.
| Syntax: | uninitialized_variable_warn  | 
|---|---|
| Default: | uninitialized_variable_warn on; | 
| Context: | http,server,location,if | 
Controls whether warnings about uninitialized variables are logged.
Internal Implementation
The ngx_http_rewrite_module module directives are compiled at the configuration stage into internal instructions that are interpreted during request processing. An interpreter is a simple virtual stack machine.
For example, the directives
location /download/ {
    if ($forbidden) {
        return 403;
    }
    if ($slow) {
        limit_rate 10k;
    }
    rewrite ^/(download/.*)/media/(.*)\..*$ /$1/mp3/$2.mp3 break;
}
will be translated into these instructions:
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
Note that there are no instructions for the limit_rate directive above as it is unrelated to thengx_http_rewrite_module module. A separate configuration is created for the if block. If the condition holds true, a request is assigned this configuration where limit_rate equals to 10k.
The directive
rewrite ^/(download/.*)/media/(.*)\..*$ /$1/mp3/$2.mp3 break;
can be made smaller by one instruction if the first slash in the regular expression is put inside the parentheses:
rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$2.mp3 break;
The corresponding instructions will then look like this:
match of regular expression
copy $1
copy "/mp3/"
copy $2
copy ".mp3"
end of regular expression
end of code
Module ngx_http_rewrite_module的更多相关文章
- Tengine 常用模块使用介绍
		Tengine 和 Nginx Tengine简介 从2011年12月开始:Tengine是由淘宝网发起的Web服务器项目.它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能 和特性. ... 
- 把www.domain.com均衡到本机不同的端口  反向代理 隐藏端口 Nginx做非80端口转发 搭建nginx反向代理用做内网域名转发  location 规则
		负载均衡-Nginx中文文档 http://www.nginx.cn/doc/example/loadbanlance.html 负载均衡 一个简单的负载均衡的示例,把www.domain.com均衡 ... 
- centos 7 搭建 LNMP ( Linux+Nginx+MySQL+PHP )
		操作系统 | CentOS Linux release 7.6.1810 (Core) [root@localhost ~# cat /etc/redhat-release CentOS Linux ... 
- 端口被占用通过域名的处理 把www.domain.com均衡到本机不同的端口  反向代理 隐藏端口 Nginx做非80端口转发 搭建nginx反向代理用做内网域名转发  location 规则
		负载均衡-Nginx中文文档 http://www.nginx.cn/doc/example/loadbanlance.html 负载均衡 一个简单的负载均衡的示例,把www.domain.com均衡 ... 
- nginx学习笔记——http module分析
		源码:nginx 1.12.0 nginx由于其高性能.扩充性好等特点在迅速走红,越来越多的公司采用nginx作web服务器.负载均衡.waf等 工作,一些基于nginx ... 
- Android Studio 编译单个module
		前期自己要把gradle环境变量配置好 在Terminal中gradle命令行编译apk 输入gradle assembleRelease 会编译全部module编译单个modulecd ./xiru ... 
- ABP源码分析三:ABP Module
		Abp是一种基于模块化设计的思想构建的.开发人员可以将自定义的功能以模块(module)的形式集成到ABP中.具体的功能都可以设计成一个单独的Module.Abp底层框架提供便捷的方法集成每个Modu ... 
- nodejs模块中exports和module.exports的区别
		通过Node.js的官方API可以看到Node.js本身提供了很多核心模块 http://nodejs.org/api/ ,这些核心模块被编译成二进制文件,可以require('模块名')去获取:核心 ... 
- ES6之module
		该博客原文地址:http://www.cnblogs.com/giggle/p/5572118.html 一.module概述 JavaScript一直没有模块体系,但是伴随着ES6的到来,modul ... 
随机推荐
- swagger2注解使用方法
			swagger注解整体说明: @Api:用在请求的类上,表示对类的说明 tags="说明该类的作用,可以在UI界面上看到的注解" value="该参数没什么意义,在UI界 ... 
- [Abp vNext微服务实践] - 添加中文语言
			简介 abp vNext中提供了多语言功能,默认语言是英文,没有提供中文语言包.在业务开发中,定义权限后需要用中文的备注提供角色选择,本篇将介绍如何在abp vNext中加入中文语言. step1:添 ... 
- [Educational Codeforces Round 63 ] D. Beautiful Array (思维+DP)
			Educational Codeforces Round 63 (Rated for Div. 2) D. Beautiful Array time limit per test 2 seconds ... 
- iOS   RAC使用补充
			1 延迟执行 [[RACScheduler mainThreadScheduler] afterDelay: schedule:^{ NSLog(@"延迟执行.."); }]; ... 
- Orchard Core 使用工作流处理页面提交
			上一篇文章中:Orchard Core 使用工作流处理审批和创建内容项 我们介绍了如何使用工作流处理审批,通过此文章我们了解到工作流的简单使用.但提交数据来自于Postman 本次文章我将演示如何从页 ... 
- kudu_CM安装准备工作
			Cloudera Manager简介: hadoop: https://yq.aliyun.com/articles/60759 ----------------------------------- ... 
- 前端知识体系:JavaScript基础-原型和原型链-实现继承的几种方式以及他们的优缺点
			实现继承的几种方式以及他们的优缺点(参考文档1.参考文档2.参考文档3) 要搞懂JS继承,我们首先要理解原型链:每一个实例对象都有一个__proto__属性(隐式原型),在js内部用来查找原型链:每一 ... 
- CCPC 2017 哈尔滨 L. Color a Tree && HDU 6241(二分+树形DP)
			题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6241 题意:给你一棵有 n 个结点的树,每个结点初始颜色都为白色,有 A 个条件:结点 x_i 的黑色 ... 
- java.util.Queue
			转载于:https://www.runoob.com/java/data-queue.html 队列是一种特殊的线性表,它只允许在表的前端进行删除操作,而在表的后端进行插入操作. LinkedList ... 
- Luogu P5048 [Ynoi2019模拟赛]Yuno loves sqrt technology III 分块
			这才是真正的$N\sqrt{N}$吧$qwq$ 记录每个数$vl$出现的位置$s[vl]$,和每个数$a[i]=vl$是第几个$vl$,记为$P[i]$,然后预处理出块$[i,j]$区间的答案$f[i ... 
