Am descoperit că site-ul meu are această problemă și nu am reușit să o rezolv. Am încercat mai multe lucruri, cum ar fi să verific dacă locațiile prefixate părinte pentru directivele alias Nginx se termină cu un separator de director, dar nu am avut noroc până acum. Merge_slashes on - este setarea implicită. Am citit despre AppArmour sau SELinux. Asta e calea de urmat? Am Ubuntu 18. Cu alte cuvinte, pot descărca acest fișier http://example.com///etc/passwd și vreau să evit asta. Orice ajutor este apreciat. Iată configurația mea:
Server {
asculta 80;
numele serverului
.example.com;
returnează 301 https://example.com$request_uri;
}
Server {
numele serverului
www.example.com;
asculta 443 ssl http2;
ssl_prefer_server_ciphers Activat;
ssl_session_cache shared:SSL:10m;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_dhparam /etc/ssl/certs/dhparam.pem;
ssl_ciphers '......
ssl_certificat /...crt;
cheie_certificat_ssl /..key;
returnează 301 https://example.com$request_uri;
}
Server {
numele serverului
exemplu.com;
asculta 443 ssl http2;
ssl_prefer_server_ciphers Activat;
ssl_session_cache shared:SSL:10m;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_dhparam /etc/ssl/certs/dhparam.pem;
ssl_ciphers '...
ssl_certificat /...crt;
cheie_certificat_ssl /.....cheie;
add_header x-frame-options „SAMEORIGIN” întotdeauna;
add_header x-xss-protection "1; mod=bloc" întotdeauna;
add_header X-Content-Type-Options nosniff;
add_header Strict-Transport-Security "max-age=63072000; includeSubdomains; $
root /var/www/www.example.com;
index index.php;
client_max_body_size 10M;
access_log /var/log/nginx/example.com.log;
error_log /var/log/nginx/example.com.error.log eroare;
Locație / {
try_files $uri $uri/ /index.php;
}
locație /cumpărături/ {
index index.php index.html index.htm;
rescrie ^/shop/wp-json/(.*?)$ /shopping/index.php?rest_route=/$1 ultimul;
try_files $uri $uri/ /shop/index.php?q=$uri&$args;
}
locație ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
expiră 24h;
log_not_found off;
}
locație ~ \.php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass unix:/var/run/php-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
locație ~\.(log|salvare|htaccess|json|csv|txt|xls)$ {
nega totul;
pagina_eroare 403 =404 / ;
}
locație ~* /(?:uploads|fișiere)/.*\.php$ {
nega totul;
}