Назад | Перейти на главную страницу

NGINX: статически обслуживать / images / папку

Я уже столько всего перепробовал, чтобы сделать это, также поместив файл php в /images/test.php, чтобы проверить, будет ли он загружен или выполнен, и он всегда запускается.

Кроме того, у меня много переписываний seo, поэтому я действительно не знаю, что происходит.

Это то, что я сейчас пытаюсь (и я уже написал об этом много документов):

Конфигурация сервера:

user nginx nginx;
worker_processes 1;

error_log /var/log/nginx/error_log info;

events {
    worker_connections 1024;
    use epoll;
}

http {
    #proxy_cache off;
    include /etc/nginx/mime.types;
    default_type application/octet-stream;

    log_format main
        '$remote_addr - $remote_user [$time_local] '
        '"$request" $status $bytes_sent '
        '"$http_referer" "$http_user_agent" '
        '"$gzip_ratio"';

    client_header_timeout 10m;
    client_body_timeout 10m;
    send_timeout 10m;

    connection_pool_size 256;
    client_header_buffer_size 1k;
    large_client_header_buffers 4 2k;
    request_pool_size 4k;

    gzip on;
    gzip_min_length 1100;
    gzip_buffers 4 8k;
    gzip_types text/plain;

    output_buffers 1 32k;
    postpone_output 1460;

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;

    keepalive_timeout 75 20;

    ignore_invalid_headers on;

    index index.php;
    proxy_buffering on;
    proxy_buffer_size 8k;
    proxy_buffers 2048 8k;

    server {
        listen 127.0.0.1;
        server_name <<my_domain>>;

        access_log /var/log/nginx/access_<<my_domain>> main;
        error_log /var/log/nginx/error_<<my_domain>> info;

        root <<doc_root>>;

        error_page 403 /errors.php?type=403;
        error_page 404 /errors.php?type=404;

        location ~* /images  {
            root    <<doc_root>>;
            #expires 30d;
        }

        location ~ \.php$ {
            #internal;
            try_files $uri =404;
            expires off;
            include /etc/nginx/fastcgi.conf;
            fastcgi_pass unix:/var/run/php-fpm.socket;
        }

        #For virtual folders which are links seo-friendly and language
                location ~ (*UTF8)^.*$ {
                        include "rewrites.conf";
                }

    }

    server {
        listen 127.0.0.1:443;
        server_name <<my_domain>>;

        ssl on;
        ssl_certificate /etc/ssl/nginx/.crt;
        ssl_certificate_key /etc/ssl/nginx/.key;
        ssl_session_cache shared:SSL:10m;
        ssl_session_timeout 10m;
        ssl_ciphers ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:DHE-RSA-AES256-SHA384:DHE-RSA-AES256-SHA256:RC4-SHA;
        ssl_protocols TLSv1.2 TLSv1.1 TLSv1 SSLv3;
        ssl_prefer_server_ciphers on;

        access_log /var/log/nginx/access_ssl_<<my_domain>> main;
        error_log /var/log/nginx/error_ssl_<<my_domain>> info;

        root <<doc_root>>;
        error_page 403 /errors.php?type=403;
        error_page 404 /errors.php?type=404;

        <<the_same_locations_than_www_server_before>>
    }
}

Итак, могу ли я обслужить весь контент внутри /images/ статически без прохождения через php? В этом тестовом примере файл /images/test.php следует скачать, а не показывать phpinfo();

Поскольку ~ * совпадает, но продолжает поиск других совпадений регулярного выражения, я думаю, что вам нужно:

    location ^~ /images/  {
        #This should match /images/ and stop checking.
        root    <<doc_root>>;
        #expires 30d;
    }

    location ~ \.php$ {
        #internal;
        try_files $uri =404;
        expires off;
        include /etc/nginx/fastcgi.conf;
        fastcgi_pass unix:/var/run/php-fpm.socket;
    }

В зависимости от ваших блоков местоположения файлы с расширением «.php» будут передаваться только через PHP. Поэтому, если у вас есть реальный файл в каталоге / images, он должен использоваться как статический файл или иным образом возвращать ошибку 404. Если файл заканчивается на '.php' и находится в каталоге '/ images', он будет проходить через оба блока местоположения по порядку.

Должно ли быть иначе?