nginx + php-fpm: ¿dónde están mis parámetros de $ _GET?

34

Tengo un problema extraño aquí. Me acabo de mudar de apache + mod_php a nginx + php-fpm. Todo salió bien, excepto este problema.

Tengo un sitio, digamos example.com. Cuando accedo a él como example.com?test=get_param $_SERVER['REQUEST_URI']es /?test=get_paramy hay un $_GET['test']también.

Pero cuando el acceso que example.com/ajax/search/?search=get_param $_SERVER['REQUEST_URI']está /ajax/search/?search=get_paramembargo, no hay $_GET['search'](no hay $_GETvariedad en absoluto).

Estoy usando el marco de Kohana. qué rutas /ajax/searchal controlador, pero he puesto phpinfo()en, index.phpasí que estoy buscando $_GETvariables antes de que el marco haga algo (esto significa que la desaparición de los parámetros no son fallas del marco).

Mi nginx.conf es así

worker_processes  4;
pid        logs/nginx.pid;
events {
    worker_connections  1024;
}
http {
    index index.html index.php;
    autoindex on;
    autoindex_exact_size off;
    include       mime.types;
    default_type  application/octet-stream;
    server_names_hash_bucket_size 128;
    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  logs/access.log  main;
    error_log   logs/error.log   debug;

    sendfile        on;
    tcp_nopush      on;
    tcp_nodelay     off;

    keepalive_timeout  2;

    gzip  on;
    gzip_comp_level 2;
    gzip_proxied any;
    gzip_types text/plain text/css application/x-javascript text/xml application/xml     application/xml+rss text/javascript;


    include sites-enabled/*;
}

y example.conf es así

server {
  listen 80;
  server_name www.example.com;
  rewrite ^ $scheme://example.com$request_uri? permanent;
}




server {
    listen   80;
    server_name example.com;
    root /var/www/example/;

    location ~ /\. {
        return 404;
    }

    location / {
        try_files $uri $uri/ /index.php;
    }

    location ~ \.php$ {
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        /usr/local/nginx/conf/fastcgi_params;
    }

    location ~* ^/(modules|application|system) {
        return 403;
    }

        # serve static files directly
        location ~* ^.+.(jpg|jpeg|gif|css|png|js|ico|html|xml|txt)$ {
                access_log        off;
                expires           30d;
        }
}

fastcgi_params es así

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  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;


fastcgi_connect_timeout 60;
fastcgi_send_timeout 180;
fastcgi_read_timeout 180;
fastcgi_buffer_size 128k;
fastcgi_buffers 4 256k;
fastcgi_busy_buffers_size 256k;
fastcgi_temp_file_write_size 256k;
fastcgi_intercept_errors on;


fastcgi_param QUERY_STRING    $query_string;
fastcgi_param PATH_INFO       $fastcgi_path_info;

¿Cuál es el problema aquí?

Por cierto, hay pocos sitios más en el mismo servidor, tanto basados ​​en Kohana como en php simple, que funcionan perfectamente.

égida
fuente

Respuestas:

73

No está pasando argumentos de obtención en su llamada a try_files

en la pregunta:

location / {
    try_files $uri $uri/ /index.php;
}

Debiera ser:

location / {
    try_files $uri $uri/ /index.php?$query_string;
}

Puede usar $ query_string o $ args , son equivalentes, excepto que $query_stringes de solo lectura (o alternativamente, $argspuede actualizarse con cualquier otra lógica que desee agregar)

AD7six
fuente
3
La propia documentación de +1 Slim está mal .
Brodie
^ ídem; Pasé horas tratando de arreglar lo miserable para otro proyecto. Gracias ad7six.
Rijndael
2
De la última documentación de Slim3:try_files $uri $uri/ /index.php$is_args$args;
mixdev
¿Qué pasa si estamos usando php-fpm en lugar de fastcgi? No podemos usar la configuración en fastcgi.conf para recuperar el nombre de la variable "$ query_string"
NaturalBornCamper
2
location / {
   try_files $uri $uri/ /index.php$is_args$args;
}
Smokie
fuente
1

Prueba mis reglas:

location / {
    try_files $uri $uri/ @koh;
}

location @koh {
    fastcgi_pass   127.0.0.1:9000;
    fastcgi_index  index.php;
    fastcgi_param  SCRIPT_FILENAME  /var/www/example/index.php;
    include        /usr/local/nginx/conf/fastcgi_params;
}

También elimine "fastcgi_param QUERY_STRING" duplicado en fastcgi_params.

alvosu
fuente
Esto no funciona En el ajax/searchda 500 error, en example.com aparece una ventana de descarga y el archivo descargado es index.php
egis
1
De todos modos, se me ocurrió una respuesta, try_files $uri $uri/ index.php;debe ser try_files $uri $uri/ /index.php?$args; #or /index.php?$query_string, mind the '?', pero sería bueno que alguien explicara esto :)
egis
por cierto, el registro de errores para su configuración, alvosu, dice could not find named location @koh.
egis
Lo siento, me equivoqué. Corregí "ubicación".
alvosu