Как перенаправить старые PHP-скрипты в конфигурации NGINX на новый HTTPS-сайт?

Как перенаправить старые PHP-скрипты в конфигурации NGINX на новый HTTPS-сайт?

У меня возникла проблема: я пытаюсь перехватить все PHP-скрипты, кроме одного, в моей конфигурации NGINX для конфигурации моего домена HTTP:

У меня есть общее правило для всех PHP-файлов

    location ~ \.php$ {

    include fastcgi_params;

    try_files $uri =404;
    fastcgi_split_path_info ^(.+\.php)(/.+)$;
    # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini

    # With php5-fpm:
    fastcgi_pass unix:/var/run/php7.4-fpm.$user.sock;
    #fastcgi_pass php7-fpm-sock;

    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

    fastcgi_read_timeout 600;
}

Но мне нужно обработать старый PHP-скрипт со старого сайта, чтобы перенаправить на HTTPS-ссылку (с другой структурой).

Я попытался поместить это в обработчик PHP, врасположение / {}блок, вместоположение /скачать {}блок, но все это терпит неудачу, и на этом скрипте срабатывает триггер по умолчанию (404 в обработчике PHP)

    rewrite ^/download\.php\?file_id=(.*)$ https://$server_name/download/id/$1 permanent;

Как правильно с этим справиться? Где в конфигурации NGINX прописать это исключение, чтобы оно заработало? Что я делаю не так?

P.S. Мне нужно сохранить отдельную конфигурацию HTTP для других вещей.

решение1

Хорошо, я нашел ответ. Порядок действий важен, он хорошо объяснен на

https://stackoverflow.com/questions/59846238/guide-on-how-to-use-regex-in-nginx-location-block-section

И решение выглядит так:

location ^~ /download.php {
    rewrite ^ https://$server_name/download/id/$arg_file_id permanent;
}

Связанный контент