Nginx重写规则
Nginx的重写规则,依赖于pcre库(perl compatible regular expression)。所以在安装的时候一定要让nginx支持这个功能,以及安装pcre-devel,prce.
nginx rewrite 正则表达式匹配
大小写匹配
~ 为区分大小写匹配
~* 为不区分大小写匹配
!~和!~*分别为 区分大小写但不匹配 及 不区分大小写但不匹配
^~ URI 不使用正则匹配,可用使用元字符匹配
文件及目录匹配
-f和!-f用来判断是否存在文件
-d和!-d用来判断是否存在目录
-e和!-e用来判断是否存在文件或目录
-x和!-x用来判断文件是否可执行
flag标记
last本次重写完成之后,重启下一轮检查 a[test]->a[test] ,注意如果重写规则的uri中和本段的location中uri有重复,则注意避免死循环,死循环10次后会返回500错误。
break 终止匹配, 不再匹配本段的内容。a[test]->b[test] completed!
redirect 返回302临时重定向 地址栏会显示跳转后的地址。
permanent 返回301永久重定向 地址栏会显示跳转后的地址。
break和last区别举例:
####
server {
...
rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$2.mp3 last;
rewrite ^(/download/.*)/audio/(.*)\..*$ $1/mp3/$2.ra last;
return 403; #本段中location中匹配的内容和重写规则中没有重复的
...
}
But if these directives are put inside the "/download/" location, the last flag should be replaced by break, 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指定的使用:格式和c语言相同,
if (condition){
rewrite …
}
注意这里的if不支持嵌套,也不支持&& 和 ||逻辑判断
set 使用:set var $avg
rewrite_log:默认off,如果为on话,会以notic级别记录到error.log
一些例子:
-
http转https:rewrite ^(.*) https://www.wxl.com$1 permanent;
-
域名跳转,将bbsX.wxl.com 转到http://www.baidu.com
location / {
root html;
index index.html index.htm;
if ($host ~ '^bbs\d{1}\.wxl\.com'){
rewrite ^(.*) http://www.baidu.com$1 permanent;
}
}
3.文件读写分离:文件上传的WebDav,基于http1.1协议,扩展了http1.1,在GET,POST,HEAD的其他功能,在我们作实验的时候,可以使用Apache打开Dav On
location / {
proxy_pass http://read_upstream;
if ($request_method = "PUT"){
proxy_pass http://write_upsteam;
}
}
4. 目录自动添加/,这个功能一般浏览器自动完成.如果使用index.html在二级目录下,比如/data/bbs/index.html,如果输入/data/bbs浏览器不会跳转到主页面index.html
location ^~ /bbs {
if (-d $request_filename){
rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
}
}
如果uri中有很多目录的话,将不利于搜索引擎的搜索,通过重写规则可以让uri目录看起来很少。
rewrite ^/server-([0-9]+)/ -([0-9]+)/ -([0-9]+)/ -([0-9]+)/\.html$ /server/$1/$2/$3/$4.html last;
break;
这样地址栏输入http://www.wxl-dede.com/server-12-12-12-12.html,
实际访问的是http://www.wxl-dede.com/server/12/12/12/12.html
location ~ ^/(cron|templates)/ {
deny all; break;
}
if ($http_user_agent ~ Chrome){
rewrite ^(.*)$ /data/index.html break;
}
location ~* \.(js|css|jpg|jpeg|gif|png|swf)$ {
if (-f $request_filename) {
expires 1h;
break;
}
}
Nginx防盗链
盗链的概念,自己网站不存在的资源,链接到其他网站的资源。但对其他网站会造成额外的消耗,unfair。
在http的请求头部中refrer头域中的值记录访问目标的源地址,因此在nginx中可以通过制定合法的URL,来防止防盗链。
语法: valid_referers none | blocked | server_names | string …;
none 来源头部为空的情况
blocked 防火墙删除了http://或者 https://
server_names 制定特定的主机,支持匹配符,支持正则
例子:基于资源的防盗链
location ~* ^.+\.(jpg|jpeg|gif|png|swf|rar|zip|css|js)$ {
valid_referers none blocked *.wxl.com;
if ($invalid_referer) {
return 403;
rewrite ^/ http://img.jjonline.cn/forbid.gif;
break;
}
对jpg,jpeg等资源进行防止盗链。
当然也可以基于目录
root /server/file/;
valid_referers none blocked *.wxl.com;
if ($invalid_referer) {
return 403;
rewrite ^/ http://img.jjonline.cn/forbid.gif;
break;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!