Блог компанії 3v-Hosting

Як перенаправити та перезаписати URL за допомогою файлу .htaccess

Адміністрування

12 хв.


У веб-розробці та керуванні серверами можливість маніпулювання URL-адресами має найважливіше значення. Одним із найпотужніших інструментів для цієї мети є файл .htaccess, файл конфігурації, який використовується веб-серверами Apache. Він дозволяє адміністраторам виконувати різні директиви, включаючи перенаправлення (Redirect) та перезапис (Rewrite) URL, не вимагаючи доступу до основних файлів конфігурації сервера. Файл .htaccess може керувати широким спектром функцій веб-сервера, що робить його найважливішим компонентом у наборі інструментів веб-розробників та системних адміністраторів.

У цій статті ми розберемося у всіх тонкощах перенаправлення та перезапису URL за допомогою файлу .htaccess, розглянемо принципи, що лежать в основі цих операцій, вивчимо синтаксис, що використовується в .htaccess, та обговоримо поширені варіанти використання цих директив. Крім того, ми обговоримо потенційні підводні камені та дамо поради щодо усунення можливих проблем, щоб забезпечити правильну роботу редиректів та рерайтів.

 

 

 


Про являє собою файл .htaccess

 

Файл .htaccess (скорочення від Hypertext Access) — це потужний конфігураційний файл, який використовується на веб-серверах, що працюють під керуванням програмного забезпечення Apache HTTP Server. Він дозволяє децентралізовано керувати конфігурацією сервера, надаючи веб-майстрам можливість контролювати установки окремих каталогів та їх підкаталогів. Файл .htaccess розміщується в каталозі, яким він керує, і може містити різні директиви, включаючи директиви для перенаправлення та перезапису URL-адрес.

Перенаправлення та переписування є основними операціями у веб-розробці. Вони дозволяють вам змінити спосіб доступу користувачів до вашого контенту та гарантувати, що URL-адреси структуровані зручним для користувача та SEO-оптимізованим чином. Поширені сценарії включають:

  Перенесення веб-сайту на новий домен: вам може знадобитися перенаправити користувачів зі старого домену на новий, не порушуючи існуючі посилання.
  Реструктуризація URL-адрес веб-сайту: у міру розвитку вашого веб-сайту вам може знадобитися реорганізувати структуру URL-адрес для покращення навігації та SEO.
  Створення зручних для користувача URL-адрес: Переписування дозволяє вам надавати користувачам більш чисті та описові URL-адреси, зберігаючи складні рядки запитів на бекенді.
  Вирішення проблем канонізації: Перенаправлення можуть допомогти керувати дубльованим контентом, гарантуючи, що пошукові системи індексують лише кращу версію сторінки.

 

 

 

Перенаправлення URL-адрес за допомогою .htaccess

 

Перенаправлення — це процес перенаправлення відвідувачів з однієї URL-адреси на іншу. Файл .htaccess допускає різні типи перенаправлень, кожен із яких має різні цілі. Два найбільш поширені типи перенаправлень:

  301 Redirect (Permanent): повідомляє браузерам та пошуковим системам, що сторінку назавжди переміщено в нове місце. Він передає майже все значення SEO новій URL-адресі, що робить його ідеальним для міграції веб-сайтів та зміни структури URL-адрес.
  302 Redirect (Temporary): повідомляє браузерам та пошуковим системам, що сторінку тимчасово переміщено в нове місце. Він не передає значення SEO новій URL-адресі, що корисно, коли контент тимчасово недоступний.

 


Реалізація перенаправлення 301

Для реалізації перенаправлення 301 у файлі .htaccess можна використовувати наступний синтаксис:

 

  Redirect 301 /old-page.html http://www.example.com/new-page.html

 

Ця директива повідомляє серверу про необхідність постійного перенаправлення будь-яких запитів на /old-page.html на http://www.example.com/new-page.html. Наприклад, якщо ви переносите свій веб-сайт на новий домен, ви можете використовувати наступний код для перенаправлення всього трафіку зі старого домену на новий:

 

  RewriteEngine On
  RewriteCond %{HTTP_HOST} ^olddomain\.com$ [NC]
  RewriteRule ^(.*)$ http://newdomain.com/$1 [R=301,L]

 

У цьому прикладі директива RewriteEngine On активує модуль mod_rewrite, що дозволяє виконувати складні маніпуляції з URL. Директива RewriteCond перевіряє, чи виходить запит із olddomain.com, а директива RewriteRule перенаправляє весь трафік на newdomain.com, зберігаючи при цьому решту шляху URL.

 

 

Реалізація перенаправлення 302

Перенаправлення 302 є корисним, якщо ви хочете тимчасово перенаправити користувачів на іншу сторінку. Синтаксис схожий на синтаксис перенаправлення 301:

 

  Redirect 302 /old-page.html http://www.example.com/temporary-page.html

 

Ця команда тимчасово перенаправляє запити з /old-page.html на http://www.example.com/temporary-page.html.

Наведений нижче приклад перенаправляє весь трафік з URL-адрес, що починаються з /promo, на спеціальну цільову сторінку, яка може бути корисною під час маркетингової кампанії.

 

  RewriteEngine On
  RewriteCond %{REQUEST_URI} ^/promo
  RewriteRule ^(.*)$ http://www.example.com/promo-landing-page [R=302,L]

 

 

 

 

Перезапис URL за допомогою .htaccess

 

У той час як перенаправлення змінює URL-адресу в адресному рядку браузера - перезапис змінює URL всередині веб-сервера до того, як запит буде оброблений сервером. Це дозволяє вам підтримувати чисті, зручні для користувача URL, зберігаючи при цьому базову структуру сайту незайманою.

Увімкнення можливості перезапису URL у .htaccess здійснюється за допомогою директиви RewriteEngine. Ви повинні включити цю директиву на початок вашого файлу .htaccess, щоб активувати модуль mod_rewrite:

 

  RewriteEngine On

 

Базовим компонентом перезапису URL-адрес є директива RewriteRule з наступним синтаксисом::

  RewriteRule Pattern Substitution [Flags]

  Шаблон: це регулярний вираз, який відповідає запрошеному URL.
  Підстановка: це вказує на новий URL для обслуговування, якщо шаблон збігається.
  Прапори: це необов'язкові параметри, які змінюють поведінку правила (наприклад, [R=301,L] для постійного перенаправлення та останнього правила).


Припустимо, ви хочете переписати URL, наприклад /product?id=123, в більш популярний формат, наприклад /product/123. Ви можете зробити це за допомогою наступної директиви .htaccess:

 

  RewriteEngine On
  RewriteRule ^product/([0-9]+)$ /product?id=$1 [L]

 

У цьому прикладі шаблон ^product/([0-9]+)$ відповідає URL, наприклад /product/123, де 123 може бути будь-яким числом. Підстановка /product?id=$1 переписує URL внутрішньо, дозволяючи вашому додатку обробляти запит, використовуючи вихідний рядок запиту.

Якщо ви не знайомі з концепцією регулярних виразів, ми рекомендуємо вам прочитати про це, оскільки без розуміння регулярних виразів вам буде складно працювати з переписуванням.

 


 

Інші корисні статті для адміністраторів:


    - 10 корисних консольних утиліт для моніторингу Linux-сервера

    - Короткий посібник із встановлення та налаштування WordPress на Linux VPS

    - Як створити чудову домашню сторінку для веб-сайту

    - Помилка 502 Bad Gateway: що це таке та як її виправити

 


 

Розширені методи перезапису URL

 

Для більш складних сценаріїв можна використовувати умови та прапори для керування потоком перезапису URL-адрес.

 

Умови у RewriteRule

Директива RewriteCond дозволяє застосовувати умови до правил перезапису. Це корисно, коли ви хочете застосовувати переписування лише за умови дотримання певних умов. Наприклад, ви можете перенаправляти користувачів на основі рядка user-agent їх браузера, що корисно для переведення користувачів мобільних пристроїв на мобільну версію сайту:

 

  RewriteEngine On
  RewriteCond %{HTTP_USER_AGENT} ^Mozilla [NC]
  RewriteRule ^(.*)$ http://m.example.com/$1 [R=302,L]

 

У цьому прикладі користувачі з браузерами, які включають рядок Mozilla у параметрі user-agent, перенаправляються на мобільну версію сайту.


Прапори в RewriteRule

Прапори змінюють роботу RewriteRule. Ось деякі основні прапори:

  [L] (Last): зупиняє обробку файлу .htaccess під час збігу цього правила.
  [R=301] (Redirect): перенаправлення 301.
  [NC] (No Case): робить правило нечутливим до регістру.
  [QSA] (Query String Append): додає рядок запиту з вихідної URL-адреси до переписаної URL-адреси.


А тепер давайте на прикладі розглянемо використання кількох прапорів одразу:

 

  RewriteEngine On
  RewriteCond %{HTTP_HOST} ^www\.example\.com$ [NC]
  RewriteRule ^(.*)$ http://example.com/$1 [R=301,L]

 

У цьому прикладі прапор [NC] робить умову нечутливою до регістру, а прапори [R=301,L] гарантують, що буде виконано перенаправлення 301 і ніякі подальші правила не будуть оброблені.

 

 

 

 

Redirect та Rewrite: коли що використовувати?

 

Хоча redirect і rewrite часто використовуються як взаємозамінні, але насправді вони служать різним цілям:

  Redirect: коли вам потрібно змінити URL-адресу, що відображається в браузері, як правило, при переміщенні контенту або усунення непрацюючих посилань. Redirects звертаються до користувача та впливають на SEO.
  Rewrite: коли ви хочете змінити URL всередині, не змінюючи те, що бачить користувач. Rewrite корисні для керування чистими URL-адресами та складними рядками запитів.

Але їх використання можна поєднувати в рамках однієї конфігурації веб-сервера. Розглянемо, наприклад, сценарій, у якому ви хочете перенаправити весь трафік з www.oldsite.com на www.newsite.com, але всередині нового сайту ви хочете переписати URL для чистіших шляхів. Ви можете об'єднати правила перенаправлення та перезапису у вашому файлі .htaccess:

 

  RewriteEngine On

  # Перенаправлення старого домену на новий домен
  RewriteCond %{HTTP_HOST} ^www\.oldsite\.com$ [NC]
  RewriteRule ^(.*)$ http://www.newsite.com/$1 [R=301,L]

  # Перезапис структури URL на новому сайті
  RewriteCond %{HTTP_HOST} ^www\.newsite\.com$ [NC]
  RewriteRule ^product/([0-9]+)$ /products/details.php?id=$1 [L]

 

Ця настройка гарантує, що користувачі, які відвідують www.oldsite.com/product/123, будуть перенаправлені на www.newsite.com/product/123, а потім ця URL буде внутрішньо переписана на products/details.php?id=123 для обробки .

 

 

 


Поширені випадки використання та найкращі практики

 

Перехід на HTTPS

Зі збільшенням значущості HTTPS багато веб-сайтів перейшли з HTTP на HTTPS. Ви можете використовувати файл .htaccess, щоб гарантувати, що весь трафік HTTP перенаправляється на HTTPS:

  RewriteEngine On
  RewriteCond %{HTTPS} off
  RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]

Це правило перевіряє, чи з'єднання є незахищеним (RewriteCond %{HTTPS} off), і перенаправляє його на версію HTTPS тієї ж URL.

 

Обробка кінцевих слішів

Одноманітність URL, наприклад, постійне використання або пропуск кінцевих слешей, має вирішальне значення для запобігання проблемам з дублюванням контенту. Ви можете керувати цим за допомогою правил .htaccess:


Додавання кінцевих слішів

  RewriteEngine On
  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_URI} !(.*)/$
  RewriteRule ^(.*)$ http://www.example.com/$1/ [R=301,L]


Видалення кінцевих слішів

  RewriteEngine On
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteCond %{REQUEST_URI} (.*)/$
  RewriteRule ^(.*)/$ http://www.example.com/$1 [R=301,L]

 

Перенаправлення на основі рядків запиту

Можливо, вам потрібно буде перенаправити URL-адресу на основі параметрів рядка запиту. Наступний приклад перенаправляє користувачів із index.php?page=contact на contact.php:

  RewriteEngine On
  RewriteCond %{QUERY_STRING} page=contact
  RewriteRule ^index\.php$ /contact.php? [R=301,L]

 

 

 

 

Усунення поширених проблем

Нескінченні цикли перенаправлення

Однією з найбільш поширених проблем при використанні перенаправлень .htaccess є створення нескінченного циклу, коли правило перенаправлення багаторазово перенаправляє URL-адресу на себе. Цього можна уникнути, ретельно структурувавши умови та переконавшись, що ваші правила є взаємовиключними.

Приклад безпечного перенаправлення:

  RewriteEngine On
  RewriteCond %{HTTPS} off
  RewriteCond %{HTTP_HOST} ^example\.com$ [NC]
  RewriteRule ^(.*)$ https://www.example.com/$1 [R=301,L]

Тут умови перевіряють як протокол, і хост, щоб уникнути циклів перенаправления.

 

 


Налагодження за допомогою RewriteLog

Хоча директива RewriteLog застаріла і не використовується в останніх версіях Apache, вона, як і раніше, корисна для налагодження на старих серверах. Увімкнення ведення журналу допоможе вам побачити, як обробляються ваші правила:

  RewriteLog "/path/to/rewrite.log"
  RewriteLogLevel 3

Для нових версій вам може знадобитися читання журналу помилок веб-сервера або застосування налаштувань ведення журналу для налагодження проблем з .htaccess.

 

 

 

Обробка спеціальних символів

URL-адреси зі спеціальними символами, такими як пробіли, & або %, можуть викликати проблеми з правилами .htaccess. Ці символи повинні бути правильно закодовані у ваших правилах, інакше ви можете зіткнутися з несподіваною поведінкою.

Приклад: перенаправлення URL із спеціальними символами

  RewriteEngine On
  RewriteRule ^my\ file.html$ /my-file.html [R=301,L]

У цьому прикладі пропуск у my file.html екранується зворотною косою рисою, щоб гарантувати правильну обробку правила.

 

 

 


Висновок

Освоєння редиректів та рерайтів у файлі .htaccess необхідне для ефективного керування веб-сайтом. Незалежно від того, чи переносите ви домени, оптимізуєте URL-адреси для SEO або просто робите свій сайт більш зручним для користувачів, розуміння того, як маніпулювати URL-адресами за допомогою .htaccess, може суттєво вплинути на продуктивність та зручність використання вашого сайту.

Використовуючи правильні директиви та ретельно плануючи правила, ви можете досягти широкого спектру результатів – від простих перенаправлень до складних рерайтів URL-адрес. Однак необхідно виявляти обережність, щоб уникнути поширених пасток, таких як нескінченні цикли та неправильний порядок правил. Завдяки знанням та прикладам, представленим у цій статті, ви повинні бути добре підготовлені до ефективного впровадження та усунення несправностей перенаправлень та перезаписів .htaccess. Але якщо ви вирішите ще більше заглибитися на цю тему, тоді ви завжди можете перейти на офіційний сайт Apache і ознайомитися з їхньою офіційною документацією.