nginx中try_files的的作用一般用户url的美化:
location / {
try_files $uri $uri/ /index.php?$query_string;
}
location ~ .*\.(php|php5)?$
{
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
}
当用户请求 http://localhost/example 时,这里的 $uri 就是/example。
try_files 会到硬盘里尝试找这个文件。如果存在名为/$root/example(其中$root 是项目代码安装目录)的文件,就直接把这个文件的内容发送给用户。
显然,目录中没有叫 example 的文件。然后就看 $uri/,增加了一个 /,也就是看有没有名为 /$root/example/的目录。
又找不到,就会 fall back 到 try_files 的最后一个选项 /index.php,发起一个内部 “子请求”,也就是相当于 nginx 发起一个 HTTP 请求到http://localhost/index.php。
这个请求会被location ~ .*\.(php|php5)?$ { ... }catch 住,也就是进入 FastCGI的处理程序。而具体的 URI 及参数是在 REQUEST_URI中传递给 FastCGI 和PHP 程序的,因此不受URI变化的影响。
本文介绍Nginx中try_files指令的工作原理及其如何实现URL美化。当客户端请求特定资源时,try_files会尝试查找对应的静态文件或目录,若未找到则将请求转发至index.php进行动态处理。
1071

被折叠的 条评论
为什么被折叠?



