目前我正在使用以下方法处理php脚本:
location ~ .php$ {
fastcgi_pass 127.0.0.1:7777;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
它适用于现有脚本,但是当我在浏览器中打开 http://domain.com/somenotexistingscript.php 时,我的错误日志显示:
2013/11/10 21:20:56 [error] 32576#0: *195970 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: x.x.x.x, server: domain.com, request: "GET /somenotexistingscript.php HTTP/1.1", upstream: "fastcgi://127.0.0.1:7777", host: "domain.com"
浏览器显示"找不到文件"。我尝试在给定的块中添加try_files $uri =404
并再次打开页面。出现了默认的nginx错误页面,但日志显示:
2013/11/10 21:26:55 [error] 1284#0: *18 open() "/www/domain.com127.0.0.1:7777" failed (2: No such file or directory), client: x.x.x.x, server: domain.com, request: "GET /somenotexistingscript.php HTTP/1.1", host: "domain.com"
使用这个问题,我设法显示自定义php错误页面,但不幸的是日志仍然显示:
2013/11/10 21:20:56 [error] 32576#0: *195970 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: x.x.x.x, server: domain.com, request: "GET /somenotexistingscript.php HTTP/1.1", upstream: "fastcgi://127.0.0.1:7777", host: "domain.com"
是否可以处理不存在的脚本并且不记录任何错误信息?
解决方案
是将try_files $uri =404;
与:
fastcgi_split_path_info ^(.+.php)(/.+)$;
所以配置看起来像:
location ~ .php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+.php)(/.+)$;
fastcgi_pass 127.0.0.1:7777;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}