NginX que faz com que o arquivo PHP seja executado duas vezes

1

Estou entre uma pedra e um lugar difícil tentando descobrir por que isso está acontecendo. Por alguma razão, quando eu abro meu site, o arquivo index.php está sendo executado. Eu consegui restringi-lo ao NginX / PHP-FPM adicionando file_put_contents('runs.txt', 'executed'.PHP_EOL, FILE_APPEND); ao topo do index.php e executando-o usando o website e a linha de comando. Se eu executá-lo a partir da linha de comando, ele só gera um executed , enquanto se eu o executar a partir do site (via NginX) ele gera dois executed . O script também não está redirecionando para si mesmo porque está retornando um código de resposta 200. Além de ter que usar mais memória executando o script duas vezes, ele também estraga a proteção do CSRF fazendo com que o CSRF seja gerado uma segunda vez e, portanto, o CSRF é inútil.

Abaixo estão os meus arquivos de configuração do nginx:

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;

Se eu alterar try_files $uri $uri/ /index.php?q=$uri&$args; para try_files $uri $uri/; e exibir http://www.xyz.com/index.php , ele será executado apenas uma vez, mas eu preciso do /index.php?q=$uri&$args lá. Estou rodando o CentOS 6.5 com o nginx 1.4.4 e o PHP 5.4.23. Alguma idéia?

    
por ub3rst4r 31.01.2014 / 18:23

1 resposta

3

Eu descobri o problema. Como try_files seria redirecionado automaticamente para index.php se o URI especificado não existisse, havia uma imagem que estava faltando e quando foi aberta, ela abriu index.php novamente.

Eu consegui determinar que a imagem faltando era http://example.com/images/google.png , então encontrei a imagem e a coloquei na pasta correta (em vez de ser redirecionada de volta para index.php).

Outra solução mais adequada seria ter um bloco location /images com uma instrução try_files no arquivo website.conf (antes do bloco location / ) que, se a imagem não existir, um código de status 404 não encontrado é enviado.

location /images {
    try_files $uri =404;
}
    
por 31.01.2014 / 23:54