Ссылка $1
, которую вы используете в своем правиле, ссылается на первую захваченную группу из вашего совпадающего шаблона, но вы не определили такую группу. Вот почему он пуст, и вы переписываете его на то, что вы называете «root URL».
Взгляните на это вместо этого:
RewriteEngine on
RewriteRule ^/?(.*)/\d{4}-(.+)$ /$1/$2 [R=301,END]
Это хорошая идея для начала с временным перенаправлением 302 и измените его на постоянное перенаправление 301 позже, когда вы убедитесь, что все настроено правильно. Это предотвращает проблемы с кешированием при проверке ...
В случае, если вы получаете внутреннюю ошибку сервера (статус http 500), используя приведенное выше правило, то есть вероятность, что вы используете очень старую версию apache http сервер. В этом случае вы увидите явный намек на неподдерживаемый флаг [END]
в файле журнала ошибок вашего http-сервера. Вы можете попробовать обновить или использовать более старый флаг [L]
, он, вероятно, будет работать так же в этой ситуации, хотя это немного зависит от вашей настройки.
Эта реализация будет работать аналогично на хосте http-серверов конфигурации или внутри распределенного файла конфигурации (файл ".htaccess"). Очевидно, что модуль перезаписи должен быть загружен внутри http-сервера и включен на http-хосте. Если вы используете распределенный файл конфигурации, вам необходимо позаботиться о том, чтобы его интерпретация была вообще включена в конфигурации хоста и чтобы он находился в папке хоста DOCUMENT_ROOT
.
И общее замечание: вы должны всегда предпочитайте размещать такие правила в конфигурации хоста http-серверов вместо использования файлов распределенной конфигурации (".htaccess"). Эти распределенные файлы конфигурации добавляют сложности, часто являются причиной неожиданного поведения, их трудно отлаживать, и они действительно замедляют работу http-сервера. Они предоставляются только в качестве последнего варианта для ситуаций, когда у вас нет доступа к реальной конфигурации хоста http-серверов (читайте: действительно дешевые поставщики услуг) или для приложений, настаивающих на написании своих собственных правил (что является очевидным кошмаром безопасности).