【nginx配置】try_files详解
1. try_files详解try_files主要是能替代一些rewrite的指令,提高解析效率;
1.1 try_files的语法
[*]格式1:try_files file ... uri;
[*]格式2:try_files file ... =code;
可应用的上下文:server,location段
try_files的语法解释如下:
[*]关键点1:按指定的file顺序查找存在的文件,并使用第一个找到的文件进行请求处理
[*]关键点2:查找路径是按照给定的root或alias为根路径来查找的
[*]关键点3:如果给出的file都没有匹配到,则重新请求最后一个参数给定的uri,就是新的location匹配
[*]关键点4:如果是格式2,如果最后一个参数是 = 404 ,若给出的file都没有匹配到,则最后返回404的响应码
1.2 try_files举例理解
location /images/ {
root /opt/html/;
try_files $uri $uri/ /images/default.gif;
}
当请求 127.0.0.1/images/test.gif 会依次查找: (按指定的file顺序查找)
[*]文件127.0.0.1/opt/html/images/test.gif (查找路径按root为根路径来找)
[*]文件夹 127.0.0.1/opt/html/images/test.gif/下的index文件 ($uri/ 是把访问的链接作为一个文件夹,请求它下面的index文件)
[*]请求127.0.0.1/images/default.gif (给出的file都没匹配到,重新请求最后一个参数给定的uri,就是新的location匹配)
注意:
try-files 如果不写上 $uri/,当直接访问一个目录路径时,并不会去匹配目录下的索引页 即 访问127.0.0.1/images/ 不会去访问 127.0.0.1/images/index.html
页:
[1]