Nginx“;“中的参数数无效”;试试“U文件”;指令……”;用于PHP安全性

Nginx“;“中的参数数无效”;试试“U文件”;指令……”;用于PHP安全性,nginx,Nginx,我正在尝试使用debian风格的目录结构从共享主机的用户文件夹中的源代码运行Nginx。我尝试启动服务器时出错: [emerg] invalid number of arguments in "try_files" directive in /home/.../nginx/conf/sites-enabled/default:11 引用的行是Nginx陷阱页面中的PHP执行保护。以下是我的配置文件: nginx.conf: worker_processes 1; events { w

我正在尝试使用debian风格的目录结构从共享主机的用户文件夹中的源代码运行Nginx。我尝试启动服务器时出错:

[emerg] invalid number of arguments in "try_files" directive in /home/.../nginx/conf/sites-enabled/default:11
引用的行是Nginx陷阱页面中的PHP执行保护。以下是我的配置文件:

nginx.conf:

worker_processes 1;

events {
    worker_connections 1024;
}

http {

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    client_max_body_size 5m;

    include /home/hittingsmoke/nginx/conf/mime.types;
    default_type application/octet-stream;

    gzip on;
    gzip_disable \"msie6\";

    include /home/hittingsmoke/nginx/conf/sites-enabled/*;
}
…和可用站点/默认值:

server {
    listen       12513;

    root /home/hittingsmoke/nginx/html/;
    index index.php index.html index.htm;

    server_name _;

    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/home/hittingsmoke/php-5.3/var/run/php5-fpm.sock;
        fastcgi_param   SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_index index.php;
        include fastcgi_params;
    }
    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }

}
我的配置没有任何问题。我的设置几乎与我正在运行的Ubuntu box上的工作安装相同。我做错了什么

编辑:经过进一步测试,只有在使用带有include in nginx.conf的站点可用设置时,才会发生这种情况。如果我将网站的内容复制/粘贴到我的nginx.conf中,那么一切都正常

EDIT2:如前所述,如果我从vhosts文件中删除了try_文件,它将再次失败,并在fastcgi_参数上出现相同的错误。这是我的fastcgi_参数文件的内容。这都是默认设置:

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指令后继续出现错误的是fastcgi_param,而不是fastcgi_param*s*。

不确定这是否是您的问题,但我的try_文件位于PHP位置块之外:

location / {
    try_files $uri $uri/ =404;
}

location ~ \.php$ {
    ....
}

Nginx试图解释
try\u files
指令至少需要两条路径:

    try_files /path1$uri /path2$uri ...
使用
/dev/null
作为简单的解决方法:

    try_files $uri /dev/null =404;
或允许更多自定义的命名位置:

    try_files $uri @error
    ...
    location @error {
        ...
    }

看起来这不是我的问题。如果我将其移动到非PHP根位置,它将在fastcgi_param处失败,并出现相同数量的无效参数错误。这似乎与使用vhosts文件而不是将主机配置保存在nginx.conf中有关。如果我将sites available/default的确切内容复制/粘贴到nginx.conf中,其中包含行,那么一切都可以正常工作。