opensuse(风滚草)+ nginx + codeigniter 404问题

时间:2016-05-18 01:44:15

标签: codeigniter nginx opensuse

我已经和它斗争了一段时间,现在仍然无法让它运行起来。我使用codeigniter应用程序在opensuse风滚草上运行nginx。

我没有问题就到了首页,但任何尝试打开控制器都会因404错误而失败。

当我在Ubuntu上工作时,我能用几分钟的谷歌搜索来解决这个问题,但是由于某些原因我在努力。我附加了我的nginx默认配置文件。我必须有一些我真的没有在这里看到的东西,因为我过去一直在努力。 opengin上的nginx真的是这么痛吗?

server {
    listen       80;
    server_name  localhost;
    root /usr/share/nginx/html/;
    index index.php;

    #charset koi8-r;
    #access_log  /var/log/nginx/log/host.access.log  main;

    location / {
        root   /usr/share/nginx/html/;
        index  index.php index.html index.htm;

        ## Handling of CORS
        if ($request_method = 'OPTIONS') {
            add_header 'Access-Control-Allow-Origin' '*';
        #
        # Om nom nom cookies
        #
            add_header 'Access-Control-Allow-Credentials' 'true';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
        #
        # Custom headers and headers various browsers *should* be OK with but aren't
        #
            add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
        #
        # Tell client that this pre-flight info is valid for 20 days
        #
            add_header 'Access-Control-Max-Age' 1728000;
            add_header 'Content-Type' 'text/plain charset=UTF-8';
            add_header 'Content-Length' 0;
            return 204;
        }
        if ($request_method = 'POST') {
            add_header 'Access-Control-Allow-Origin' '*';
            add_header 'Access-Control-Allow-Credentials' 'true';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
        }
        if ($request_method = 'GET') {
            add_header 'Access-Control-Allow-Origin' '*';
            add_header 'Access-Control-Allow-Credentials' 'true';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
        }
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    location ~ \.php$ {

        try_files $uri =404;
        fastcgi_pass    127.0.0.1:9000;
        fastcgi_index   index.php;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        #fastcgi_ignore_client_abort off;
    }

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    location ~ /\.ht {
        deny  all;
    }
}

1 个答案:

答案 0 :(得分:0)

是的,我最终找到并回答了这个问题。我已经完全删除了配置文件的内容,并将其替换为我在nginx网站上发现的内容(here)。

有趣的是,如果你注意到在配置文件中没有更多的指令来处理CORS,但是所有的内容,如字体,脚本等都可以正常工作而没有本地主机上的故障。

server {
    listen       80;
    server_name  localhost;
    root /usr/share/nginx/html;
    autoindex on;
    index index.php;

    location / {

            try_files $uri $uri/ /index.php;

            location = /index.php {

                fastcgi_pass   127.0.0.1:9000;
                fastcgi_param  SCRIPT_FILENAME /usr/share/nginx/html$fastcgi_script_name;
                include        fastcgi_params;
            }
        }

        location ~ \.php$ {
            return 444;
        }

}

希望对某人有用;)