NginX导致PHP文件被执行两次

我处于一个困难的地方,试图弄明白为什么会这样。 出于某种原因,当我打开我的网站的index.php文件正在执行。 我已经能够通过添加file_put_contents('runs.txt', 'executed'.PHP_EOL, FILE_APPEND);将其缩小到NginX / PHP-FPM file_put_contents('runs.txt', 'executed'.PHP_EOL, FILE_APPEND); 到index.php的顶部,并使用网站和命令行执行它。 如果我从命令行执行它,它只输出一个executed ,而如果我从网站(通过NginX) executed它输出两个executed 。 该脚本也没有redirect到自身,因为它只是返回200响应代码。 除了通过执行脚本两次使用更多的内存之外,还通过使CSRF再次生成来消除CSRF保护,因此CSRF是无用的。

下面是我的nginxconfiguration文件:

nginx.conf

 user nginx; worker_processes 2; error_log /var/log/nginx/error.log warn; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 65; # Upstream to abstract backend connection(s) for PHP. upstream php { #this should match value of "listen" directive in php-fpm pool server unix:/var/lib/php-fpm.sock; } #gzip on; include /etc/nginx/conf.d/*.conf; } 

php.conf

 # Pass all .php files onto a php-fpm/php-fcgi server. location ~ \.php$ { #NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini include fastcgi_params; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_read_timeout 600s; # fastcgi_intercept_errors on; fastcgi_pass php; } 

website.conf

 server { listen 80; server_name xyz.com www.xyz.com; root /usr/share/nginx/xyz.com; #access_log /usr/share/nginx/logs/xyz.com-access_log; error_log /usr/share/nginx/logs/xyz.com-error_log; index index.php; location / { index index.php; try_files $uri $uri/ /index.php?q=$uri&$args; } include php.conf; } 

fastcgi_params

 fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; fastcgi_param DOCUMENT_ROOT $document_root; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param HTTPS $https if_not_empty; fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; # PHP only, required if PHP was built with --enable-force-cgi-redirect fastcgi_param REDIRECT_STATUS 200; 

如果我改变了try_files $uri $uri/ /index.php?q=$uri&$args; to try_files $uri $uri/; 并提出http://www.xyz.com/index.php然后它只会执行一次,但我需要/index.php?q=$uri&$args在那里。 我使用nginx 1.4.4和PHP 5.4.23运行CentOS 6.5。 有任何想法吗?

我发现了这个问题。 由于如果指定的URI不存在, try_files会自动redirect到index.php ,因此有一个图像丢失,当它打开时,它再次打开index.php