Nginx "ungültige Anzahl von Argumenten in "try_files" Richtlinie..." für PHP-Sicherheit
Ich versuche Nginx läuft von der Quelle in den Benutzer-Ordner von meinem shared host mit debian-style-Verzeichnis-Struktur. Ich erhalte eine Fehlermeldung, wenn ich versuche den server zu starten bis:
[emerg] invalid number of arguments in "try_files" directive in /home/.../nginx/conf/sites-enabled/default:11
Die Zeile verwiesen wird, ist die PHP-Ausführung Schutz vor den Nginx Fallstricke Seite. Hier sind meine config Dateien:
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/*;
}
...und sites-available/default:
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;
}
}
Ich kann nichts finden falsch mit meinen configs. Mein setup ist fast identisch zu einer funktionierenden installation auf einem Ubuntu-box, die bei mir läuft. Was mache ich falsch?
EDIT: Nach weiteren Tests, das passiert nur, wenn ich Sie mit einem Seiten-setup zur Verfügung, die mit einem include in der nginx.conf. Wenn ich copy/paste des Inhalts meiner sites-available/default in meine nginx.conf funktioniert alles einwandfrei.
EDIT2: Wie bereits erwähnt, wenn ich entfernt try_files aus der vhosts Datei der Fehler wieder Auftritt mit den gleichen Fehler auf fastcgi_params. Hier ist der Inhalt meiner fastcgi_params-Datei. Es ist alles Standard:
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;
EDIT3: ich habe einen leichten Fehler. Es ist fastcgi_param, nicht fastcgi_param*s*, wo der Fehler contiunes nach dem entfernen der try_files-Richtlinie.
Du musst angemeldet sein, um einen Kommentar abzugeben.
Nginx versucht zu erklären, dass die
try_files
Richtlinie muss mindestens zwei Pfade:Entweder
/dev/null
als einen einfachen work-around:Oder einen benannten Standort, der es ermöglicht, weitere Anpassung:
Nicht sicher, ob dies Ihr Problem ist, aber ich habe meine try_files außerhalb der PHP-Lage block: