Chciałbym, aby następujące adresy URL w mojej witrynie były równoważne:
/foo/bar
/foo/bar/
/foo/bar/index.html
a ponadto chciałbym, aby dwie pozostałe formularze wysyłały przekierowania HTTP 301 do pierwszej formy. Podaję tylko strony statyczne, które są ułożone zgodnie z trzecim formularzem. (Innymi słowy, gdy użytkownik zażąda /foo/bar
, powinien otrzymać plik o /usr/share/.../foo/bar/index.html
).
Mój nginx.conf
obecnie zawiera następujące elementy:
rewrite ^(.+)/$ $1 permanent;
index index.html;
try_files $uri $uri/index.html =404;
Działa to w przypadku próśb o /foo/bar/index.html
, ale gdy poproszę /foo/bar
lub /foo/bar/
Safari powie mi, że „wystąpiło zbyt wiele przekierowań” - zakładam, że istnieje nieskończona pętla przekierowań lub coś w tym rodzaju. Jak mogę zmusić nginx do mapowania adresów URL do plików w sposób opisany przeze mnie?
Edycja: Moja pełna konfiguracja
Oto moja cała nginx.conf
z nazwą mojej domeny zastąpioną przez „example.com”.
user www-data;
worker_processes 1;
pid /run/nginx.pid;
events {
worker_connections 768;
}
http {
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
server_tokens off;
server_names_hash_bucket_size 64;
include /etc/nginx/mime.types;
default_type application/octet-stream;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
gzip on;
gzip_disable "msie6";
gzip_vary on;
gzip_proxied any;
gzip_comp_level 6;
gzip_buffers 16 8k;
gzip_http_version 1.1;
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss application/atom+xml text/javascript image/svg+xml;
server {
server_name www.example.com;
listen 80;
return 301 $scheme://example.com$request_uri;
}
server {
server_name example.com 123.45.67.89 localhost;
listen 80 default_server;
# Redirect /foobar/ to /foobar
rewrite ^(.+)/$ $1 permanent;
root /usr/share/nginx/www/example.com;
index index.html;
try_files $uri $uri/index.html =404;
error_page 404 /404.html;
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}
}
/foo/bar/index.html
powinny zwrócić plik w/usr/share/nginx/www/foo/bar/index.html
takiej postaci lub w dowolnej konfiguracji. Wszystkie ścieżki na stronie odpowiadają bezpośrednio ścieżkom systemu plików.Odpowiedzi:
Posiadanie tego wyrażenia regularnego w
server
bloku:przekieruje wszystkie końcowe URL-e ukośnika na odpowiedni nieokreślony ukośnik.
źródło
Udało mi się uzyskać pożądane zachowanie, używając tego jako ostatniego
server
bloku w mojej konfiguracji:źródło
/index.html
adres URL odpowiada HTTP 200 zamiast przekierowania; linie „przepisz” są ignorowane. Czy to wciąż aktualne?Nigdy nie używaj przepisywania:
źródło
rewrite ^(.+)/+$ $1 permanent;
rewrite
może być źle. To powiedziawszy, podana odpowiedź również przechwytuje i dopasowuje URI, nie jestem pewien, czy poprawi wydajność, wymaga testowania.(?<no_slash>.+)/$
Zamiast tego użyj tego wyrażenia regularnego, aby nie przekierowywać strony głównej.Ta reguła zajmie się dowolną liczbą końcowych ukośników i zachowa adres URL. Zadba również o ukośniki końcowe URL
źródło