O front-end do nosso aplicativo não está funcionando após a migração do Apache para o Nginx

1

Este é o nosso arquivo de configuração, estamos tendo problemas com a funcionalidade front-end do aplicativo que funciona no Apache.

O método JavaScript POST não está mais funcionando.

server {

    listen   80;
    server_name website.com www.website.com;
    rewrite ^/(.*) https://website.com/$1 permanent;
}

server {

    listen   443;
    server_name website.com www.website.com;


    ssl    on;
    ssl_certificate    /etc/ssl/www_website_com.pem;
    ssl_certificate_key    /etc/ssl/website.com.key;

    ssl_session_timeout 5m;

    root        /usr/share/nginx/www.website.com;
    index index.html index.php;

    # canonicalize codeigniter url end points
    # if your default controller is something other than "welcome" you should change the following
    if ($request_uri ~* ^(/home(/index)?|/index(.php)?)/?$)
    {
            rewrite ^(.*)$ / permanent;
    }

    # removes trailing "index" from all controllers
    if ($request_uri ~* index/?$)
    {
            rewrite ^/(.*)/index/?$ /$1 permanent;
    }

    # removes trailing slashes (prevents SEO duplicate content issues)
    if (!-d $request_filename)
    {
            rewrite ^/(.+)/$ /$1 permanent;
    }

    # removes access to "system" folder, also allows a "System.php" controller
    if ($request_uri ~* ^/system)
    {
            rewrite ^/(.*)$ /index.php?/$1 last;
            break;
    }

    # unless the request is for a valid file (image, js, css, etc.), send to bootstrap
    if (!-e $request_filename)
    {
            rewrite ^/(.*)$ /index.php?/$1 last;
          break;
    }

    # catch all
    error_page 404 /index.php;

    # set expiration of assets to MAX for caching
    location ~* \.(ico|css|js|gif|jpe?g|png)(\?[0-9]+)?$ {
            expires max;
            log_not_found off;
    }

    location / {
            # Check if a file exists, or route it to index.php.
            try_files $uri $uri/ /index.php;
            auth_basic            "Restricted";
            auth_basic_user_file  /etc/nginx/htpasswd;
    }

    location ~* \.php$ {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            fastcgi_connect_timeout 60;
            fastcgi_send_timeout 180;
            fastcgi_read_timeout 180;
            fastcgi_buffers 512 32k;
            fastcgi_buffer_size 64k;
            include fastcgi_params;

    # PHP only, required if PHP was built with --enable-force-cgi-redirect
            fastcgi_param   REDIRECT_STATUS         200;
            fastcgi_param SCRIPT_FILENAME /usr/share/nginx/www.website.com$fastcgi_script_name;
    }

    location ~ /\.ht
{
    deny all;
  }

  }

Resposta:

Eu finalmente sei o que deu errado e como corrigi-lo. A configuração do nginx deve se aplicar apenas ao JS estático, e não às ações do PHP.

Configure isto:

location ~ ^/(assets)/ {
  expires max;
  break;
 }

Substitua "assets" por "js" e funcionará.

    
por Ernst 14.11.2011 / 13:14

2 respostas

1

Resposta:

Eu finalmente sei o que deu errado e como corrigi-lo. A configuração do nginx deve se aplicar apenas ao JS estático, e não às ações do PHP.

Configure isto:

location ~ ^/(assets)/ {
 expires max;
 break;
}

Substitua "assets" por "js" e funcionará.

    
por 20.12.2011 / 15:15
2

Sua regra de reescrita (permanente) retornará um redirecionamento 301 para cada solicitação, incluindo os POSTs. Então qualquer post vars será perdido

    
por 14.11.2011 / 14:50

Tags