当前位置: 代码迷 >> 综合 >> try_files的个人理解
  详细解决方案

try_files的个人理解

热度:30   发布时间:2023-09-06 22:37:46.0

以下述配置文件为例:

 

location ~ \.php$ {root           html;try_files      $uri $uri/ =404;fastcgi_pass   127.0.0.1:9000;fastcgi_index  index.php;fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;include        fastcgi_params;}


try_files的第一个‘$uri’代表nginx会去硬盘的对应路径寻找文件,如果能找到,则向下执行location块中的内容,也就是把找到的文件交给fastcgi执行,如果找不到,则尝试在访问的uri后面追加‘/’,并继续在硬盘中寻找对应目录,处理同上,否则将这次请求内部重定向到最后一个参数,也就是返回404。

这里需要注意几点:

一是访问’your.site.com/example‘时,若没有配置’$uri/‘则nginx只会去找对应的example文件,而不会找example目录;若访问’your.site.com/example/‘,nginx只会去找对应的example目录,而不会找example文件。也就是说若没有try_files这项配置,nginx会完全按照请求的uri去硬盘中找文件(不以’/‘结尾)或目录(以’/‘结尾),不会擅自加添或去掉'/'。

二是try_files只是让nginx’尝试去找文件‘,找完不会直接跳出location块,而是会顺着往下执行,后面有proxy_pass或fastcgi_pass则将找到的文件转发到对应的地方,没有proxy_pass或fastcgi_pass则直接将文件返回给客户端。当找不到文件时,将这次请求内部重定向到最后一个参数,所以最后一个参数必须存在,例如 ‘=404’或重定向到其他的location等等,若不存在,则可能出现服务器内部异常,例如循环重定向的异常。