![0941fc66c59a6cb5d8061e67284bd25d.png](https://i-blog.csdnimg.cn/blog_migrate/6470c03fbba2a081406fa611c5dfbc74.jpeg)
一、正则表达式匹配
~
为区分大小写匹配~*
为不区分大小写匹配!~
和!~*
分别为区分大小写不匹配及不区分大小写不匹配
二、文件及目录匹配
-f
和!-f
用来判断是否存在文件-d
和!-d
用来判断是否存在目录-e
和!-e
用来判断是否存在文件或目录-x
和!-x
用来判断文件是否可执行
三.rewrite指令的最后一项参数为flag标记,flag标记有
last
相当于apache
里面的[L]标记,表示rewrite
。break
本条规则匹配完成后,终止匹配,不再匹配后面的规则。redirect
返回302临时重定向,浏览器地址会显示跳转后的URL地址。permanent
返回301永久重定向,浏览器地址会显示跳转后的URL地址。
使用 last
和 break
实现URI重写,浏览器地址栏不变。
而且两者有细微差别,使用alias指令
必须用 last
标记;使用proxy_pass指令
时,需要使用break
标记。Last标记在本条rewrite规则执行完毕后,会对其所在server{……}标签重新发起请求,而break标记则在本条规则匹配完成后,终止匹配。例如:如果我们将类似URL/photo/123456
重定向到 /path/to/photo/12/1234/123456.pn
![08d06d73d342c0b45bdc4773dd784401.png](https://i-blog.csdnimg.cn/blog_migrate/6033ae349d0ef9a6584cea6ca84f85bc.png)
四、NginxRewrite规则相关指令1、break指令
使用环境:server
、location
、if
该指令的作用是完成当前的规则集,不再处理rewrite指令。2、if 指令
使用环境:server
、location
该指令用于检查一个条件是否符合,如果条件符合,则执行大括号内的语句。If指令不支持嵌套,不支持多个条件&&和||处理。3、return指令
语法:returncode
使用环境:server
、location
、if
该指令用于结束规则的执行并返回状态码给客户端。示例:如果访问的URL以".sh"或".bash"结尾,则返回403状态码
![bc7f9da84c5a89add9af0b01f2ede185.png](https://i-blog.csdnimg.cn/blog_migrate/2e10a6016d46dd87de2bb0f4ae4b7435.png)
4、rewrite 指令
语法:rewriteregex replacement flag
使用环境:server
、location
、if
该指令根据表达式来重定向URI,或者修改字符串。指令根据配置文件中的顺序来执行。注意重写表达式只对相对路径有效。如果你想配对主机名,你应该使用if语句,示例如下:
![4caf650660c1bd2c5b975115e79c0bba.png](https://i-blog.csdnimg.cn/blog_migrate/31b0c67c9ad275cd7242a50106365364.png)
5、Set指令
语法:setvariable value ;
默认值:none
使用环境:server
、location
、if
该指令用于定义一个变量,并给变量赋值。变量的值可以为文本、变量以及文本变量的联合。
![cc4c378cbbe6e8c12a7707ef43b112b4.png](https://i-blog.csdnimg.cn/blog_migrate/c4bfa29dcca6c35861131d20a70bc26f.png)
6、Uninitialized_variable_warn指令
语法:uninitialized_variable_warnon|off
使用环境:http
、server
、location
、if
该指令用于开启和关闭未初始化变量的警告信息,默认值为开启。
五.Nginx的Rewrite规则编写实例1、当访问的文件和目录不存在时,重定向到某个html文件
![19937d3f7750a5baa49a2cab81a2e935.png](https://i-blog.csdnimg.cn/blog_migrate/57d3eed2a31bc98861d6961077e86b0e.png)
2、目录对换 /123456/xxxx ====> /xxxx?id=123456
![eb2998da7fbdbe1da5ce3f7e4cf33b00.png](https://i-blog.csdnimg.cn/blog_migrate/843895500e5189231225f5b914adcc7b.png)
3、如果客户端使用的是IE浏览器,则重定向到/ie目录下
![c2e13cc9a47c5a2161657ee28bd3ba7f.png](https://i-blog.csdnimg.cn/blog_migrate/9dd7c7f1b4510be87a2c57e572f976f8.png)
4、禁止访问多个目录
![1521cd8796cddb0c27fe7e972e9143de.png](https://i-blog.csdnimg.cn/blog_migrate/f5bd45f75f2bbd42e31a9442c3354a2a.png)
5、禁止访问以/data开头的文件
![603dba924e3417e1ecb7db7c483abe95.png](https://i-blog.csdnimg.cn/blog_migrate/db5fc22c68b43ff1f87ab97dfdfba82b.png)
6、禁止访问以.sh,.flv,.mp3为文件后缀名的文件
![5198dac73aa6c6bc6b0135ee1b0361a3.png](https://i-blog.csdnimg.cn/blog_migrate/fad7a1c3bb53a92354d293e2f132d43a.png)
7、设置某些类型文件的浏览器缓存时间
![5fb749d06bf6f38d6d92d6063dd2c779.png](https://i-blog.csdnimg.cn/blog_migrate/68bc68da051cd6fb07ab5a131bcdd313.png)
8、给favicon.ico和robots.txt设置过期时间
这里为favicon.ico为99天,robots.txt为7天并不记录404错误日志
![dfc542f63fcfbdff3a3c541d7e4617ee.png](https://i-blog.csdnimg.cn/blog_migrate/f0e3b3f4cda250064708d58f14fa9463.png)
9、设定某个文件的过期时间;这里为600秒,并不记录访问日志
![eb8ee53b9bb2f04a940eb553a29e6b9f.png](https://i-blog.csdnimg.cn/blog_migrate/b1419ed19b20ebe220a10cf7a8f2d590.png)
10、文件反盗链并设置过期时间
这里的return412 为自定义的http状态码,默认为403,方便找出正确的盗链的请求
![f1e7e9d4b5f9fb2faf402cf55f213041.png](https://i-blog.csdnimg.cn/blog_migrate/66cac8e7b45399c02bb1cd801f9dd552.png)
11、只允许固定ip访问网站,并加上密码
![fbd38e8826cf44cc8543cf8fec82e23e.png](https://i-blog.csdnimg.cn/blog_migrate/6cf3cc76d20140093357c9f27569cad6.png)
12、将多级目录下的文件转成一个文件,增强seo效果
![a161e5a77517b7cfb54d019ff78d3bc8.png](https://i-blog.csdnimg.cn/blog_migrate/f44f1edc98f2f635304027de2c8d11ec.png)
13、文件和目录不存在的时候重定向:
![0f810bead9b0f431e996805ca24911f7.png](https://i-blog.csdnimg.cn/blog_migrate/9da99f523c046a8a2d366d04396a5c4c.png)
14、将根目录下某个文件夹指向2级目录
![69b017f1d84ba57df7690dd440b4376d.png](https://i-blog.csdnimg.cn/blog_migrate/19f715e04dd6126f9b9a315e3c1d41ec.jpeg)
15、域名跳转
![4d21e510604eadccbd4cc5d1e8885142.png](https://i-blog.csdnimg.cn/blog_migrate/77ebca09fde89c3d6e40ce7bf864664c.png)
16、多域名转向
![265d05ab51006bc23fb37b80e607f15c.png](https://i-blog.csdnimg.cn/blog_migrate/c46cb30d744c59a07c59037a71e97902.png)
六、nginx全局变量
![56537a46a4eb13614dc37ad1e355d1c0.png](https://i-blog.csdnimg.cn/blog_migrate/a286a78d4241113c161afbf7d2c7e12c.jpeg)
七、Apache和Nginx规则的对应关系
![0231efa529232b4a87cb3c2ed1fcc6a9.png](https://i-blog.csdnimg.cn/blog_migrate/9cba181a8890e19389020fe223ca6e81.png)
例如:允许指定的域名访问本站,其他的域名一律转向www.linuxidc.net
![b512f7e0404f5d073d2ec6d0988e4b03.png](https://i-blog.csdnimg.cn/blog_migrate/79fca1e7672ac2fe6a2f17a249ebd019.png)
Nginx过滤示例:
![312d573664989541256e28d2e313d2f7.png](https://i-blog.csdnimg.cn/blog_migrate/5726f0943cbaf63e041e3d30297369d2.png)
总结
后端开发是一个最接近全栈的一个职业,前端不够用后端顶上写页面JS,没有运维不要紧后端来维护服务器,总之一个好的后端就是能面面俱到。