网站首页 > 技术教程 正文
当我们在server快下的rewrite阶段执行完毕后,
开始根据请求的URL 去匹配相应的location进行处理 这个阶段就是find_config 阶段。
merge/slashes 可以合并2个 ‘/’
location匹配规则可以分这么几类:
前缀字符串:
- 常规的,
- =:精准匹配,
- ^~:正则匹配上后则不再进行正则匹配
正则表达式:
- ~:大小写敏感的正则匹配
- ~*:忽略大小写的正则匹配
用于内部跳转的命名location:
- @
localcation匹配顺序:
先对所有的location做一次匹配,这一步和我们在.conf文件里 写的location的顺序 实际上是无关的。这里有一颗二叉树放置了匹配的前缀。
这里分3种情况:
- =完全匹配上后,则停止做匹配了。也就是说=的优先级是最高的。
- ^~ 不用进行后面的匹配了。如果有多个,那么使用最长匹配。
- 如果都没有,则记住最长前缀匹配。
此时按.conf中的顺序挨个匹配location
如果匹配上了就使用匹配上的正则表达式。
如果所有正则都不匹配,就使用最长匹配的前缀字符串。
也就是说按照匹配优先级是 正则匹配>前缀匹配的。
下面举个例子:
以下URL会返回什么内容呢?
/Test1 
/Test1/ 
/Test1/Test2 
location ~ /Test1/$ { 
  return 200 'first regular expressions match!\n'; 
} 
location ~* /Test1/(\w+)$ { 
	return 200 'longest regular expressions match!\n'; 
} 
location ^~ /Test1/ { 
	return 200 'stop regular expressions match!\n'; 
} 
location /Test1/Test2 { 
  return 200 'longest prefix string match!\n'; 
} 
location = /Test1 { 
	return 200 'exact match!\n'; 
}当我们进行以下请求的时候
1. /Test1 会匹配上最后一个location,返回 'exact match!'
2. /Test1/ 会匹配上^~ /Test1/,返回 'stop regular expressions match!'
3. /Test1/Test2 会返回什么呢?
大家思考一下, 欢迎在评论区留言。
猜你喜欢
- 2024-10-09 面试题 HTTP及web服务相关(nginx apache)
- 2024-10-09 Nginx实现认证登录(nginx登录验证)
- 2024-10-09 Nginx 是如何处理 HTTP 头部的?(女飞行员余旭遗体头部图)
- 2024-09-08 nginx 安装教程(详解)(nginx安装与配置详解)
- 2024-09-08 学习Nginx,跟着阿里大牛走,一套精心整理的Nginx(PDF文档)
- 2024-09-08 nginx实现内外网访问限制(nginx 内网)
- 2024-09-08 nginx的多域http、https同时访问配置及http重定向https
- 2024-09-08 nginx httpstatus 408 研究(404 not found nginx是什么意思)
- 2024-09-08 Nginx完全指南--内容解析(三)(nginx 详解)
- 2024-09-08 Nginx http 强转https(http://cas.tjgl.teacheredu.cn)
欢迎 你 发表评论:
- 10-23Excel计算工龄和年份之差_excel算工龄的公式year
- 10-23Excel YEARFRAC函数:时间的"年份比例尺"详解
- 10-23最常用的10个Excel函数,中文解读,动图演示,易学易用
- 10-23EXCEL中如何计算截止到今日(两个时间中)的时间
- 10-2390%人不知道的Excel神技:DATEDIF 精准计算年龄,告别手动算错!
- 10-23计算工龄及工龄工资(90%的人搞错了):DATE、DATEDIF组合应用
- 10-23Excel中如何计算工作日天数?用这两个函数轻松计算,附新年日历
- 10-23怎样快速提取单元格中的出生日期?用「Ctrl+E」批量搞定
- 最近发表
- 
- Excel计算工龄和年份之差_excel算工龄的公式year
- Excel YEARFRAC函数:时间的"年份比例尺"详解
- 最常用的10个Excel函数,中文解读,动图演示,易学易用
- EXCEL中如何计算截止到今日(两个时间中)的时间
- 90%人不知道的Excel神技:DATEDIF 精准计算年龄,告别手动算错!
- 计算工龄及工龄工资(90%的人搞错了):DATE、DATEDIF组合应用
- Excel中如何计算工作日天数?用这两个函数轻松计算,附新年日历
- 怎样快速提取单元格中的出生日期?用「Ctrl+E」批量搞定
- Excel日期函数之DATEDIF函数_excel函数datedif在哪里
- Excel函数-DATEDIF求司龄_exceldatedif函数计算年龄
 
- 标签列表
- 
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
 

本文暂时没有评论,来添加一个吧(●'◡'●)