Замените или отразите URL-адрес другого URL-адреса с помощью htacess - PullRequest
0 голосов
/ 28 апреля 2019

У меня есть веб-сайт, встроенный в WordPress, и у меня есть URL

www.mywebsite.com/product/my-new-product так что мне нужно, я хочу удалить /product из URL. я хочу www.mywebsite.com/my-new-product.

или возможно, что кто-то нажмет на www.mywebsite.com/my-new-product, тогда он покажет содержание www.mywebsite.com/product/my-new-product

Пожалуйста, проверьте

Я устал от следующего, но он тоже не работает

 RewriteEngine on
RewriteRule ^/product/my-new-product$ /my-new-product/

1 Ответ

1 голос
/ 28 апреля 2019

Перезапись работает наоборот, чем вы ожидаете. Он работает на входящих запросах, поэтому вам нужно переписать URL-адрес, который вы хотите видеть в адресной строке браузера, в соответствии с внутренними требованиями на стороне сервера:

RewriteEngine on
RewriteRule ^/?my-new-product/(.*)$ /product/my-new-product/$1 [END]

Чтобы сохранить нужный URL в адресной строке браузера, вам также необходимо позаботиться о том, чтобы на странице использовались относительные ссылки. Так что не абсолютные, относящиеся к /product/my-new-product/..., а только к /my-new-product. Это выходит за рамки переписывания, хотя.

В случае, если вы получаете внутреннюю ошибку сервера (http status 500), используя приведенное выше правило, есть вероятность, что вы используете очень старую версию apache http server. В этом случае вы увидите определенный намек на неподдерживаемый флаг [END] в файле журнала ошибок http-серверов. Вы можете попробовать обновить или использовать более старый флаг [L], он, вероятно, будет работать так же в этой ситуации, хотя это немного зависит от ваших настроек.

Это правило будет работать аналогичным образом в конфигурации хоста http-серверов или внутри файла динамической конфигурации (файл ".htaccess"). Очевидно, что модуль перезаписи должен быть загружен внутри http-сервера и включен на хосте http. Если вы используете динамический файл конфигурации, вам нужно позаботиться о том, чтобы его интерпретация вообще была включена в конфигурации хоста и чтобы он находился в папке DOCUMENT_ROOT хоста.

И общее замечание: вам всегда следует размещать такие правила в конфигурации хоста http-серверов, а не использовать файлы динамической конфигурации (".htaccess"). Эти динамические конфигурационные файлы добавляют сложность, часто являются причиной неожиданного поведения, их трудно отладить, и они действительно замедляют работу http-сервера. Они предоставляются только в качестве последнего варианта для ситуаций, когда у вас нет доступа к реальной конфигурации хоста http-серверов (читай: действительно дешевые поставщики услуг) или для приложений, настаивающих на написании своих собственных правил (что является очевидным кошмаром безопасности).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...