WOnet.ru - Хостинг
Сделать стартовой Добавить в избранное Реклама на сайте Написать нам
   КАТАЛОГ ССЫЛОК   
   МОБИЛА   
   IT-МАГАЗИН   
   SMS-ЗНАКОМСТВА   
   WEB-СТУДИЯ   
   РАСКРУТКА   

  Разделы

О компании
Способы оплаты
ВЕБ-мастерам
Вопрос/Ответ
Правила
Форум
Контакты

  Новости

[2006-07-06]
Новый Многоканальный телефон: +7(495)740 1615

[2006-07-01]
Новый дизайн Панели Управления.

[2006-05-14]
Новый способ оплаты услуг: MoneyMail

[2006-03-27]
Новый WebMail! Очередное расширение возможностей услуг хостинга.

[2005-12-15]
CMS WebDirector + 1 год хостинга в подарок!

[2005-09-24]
Неограниченное количество поддоменов.

[2005-03-02]
Новая CMS WebDirector для создания и раскрутки бизнес-сайтов на всех тарифах!

  Реклама


  Статистика





ссылки
ссылки

База знаний Хостинг.ВОнет.ру

Работа с .htaccess

  • Назначение и использование файла .htaccess
  • Индексный файл
  • Переопределение индексного файла
  • Паролирование директорий
  • Собственные страницы ошибок
  • Запрет доступа к некоторым файлам
  • Заголовок last-modified
  • Назначение и использование файла .htaccess

    Файл .htaccess (обратите внимание что первый символ в названии файла - точка) применяется для управления веб-сервером Apache со стороны конечного пользователя хостинга. Вы помещаете в этот файл директивы, которые веб-сервер воспринимает и обрабатывает, выполняя далее действия в соответствии с настройками, которые были сделаны пользователем.

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

    В .htaccess может быть помещено большинство из доступных директив для веб-сервера. Следует заметить, что директивы, в описании которых в поле Context отсутствует упоминание .htaccess недоступны для использования в этом файле конфигурации.

    Если использовать нужную директиву не получилось и вы увидели ошибку после добавления директивы в .htaccess, скорее всего использование команды запрещено в условиях виртуального хостинга. Напишите в техническую поддержку, мы постараемся вам помочь найти выход из ситуации. Просьба подробно описать проблему и указать цели, которых хотите достичь использованием данной директивы.

    Пример использования .htaccess. Мы хотим "объяснить" веб-серверу что все html-документы, которые размещены на сервере, нужно "отдавать" клиенту в кодировке koi8-r, а не в windows-1251, как это сервер делает по умолчанию. Поместим в .htaccess строку:

    AddType "text/html; charset=koi8-r" .html .htm .shtml

    Получив такой .htaccess, веб-сервер Apache станет выдавать клиентскому браузеру заголовок, в котором будет указано, что документ имеет кодировку koi8-r. Это пример простейшего использования возможностей конфигурирования Apache через файл .htaccess.

    Индексный файл

    Индексный файл или файл-индекс это файл, который открывается по умолчанию когда пользователь обращается через веб к каталогу, а не к конкретному файлу. Например, ваш посетитель запросит адрес http://ваш_домен/price/, где price - название каталога. Индексный файл это тот файл, который будет показан пользователю при обращении к каталогу без указании имени конкретного файла в нем.

    По умолчанию индексными файлами являются следующие: index.html, index.htm, index.php, index.phtml, index.shtml. Если вы хотите чтобы первым открывался какой-то иной файл, нужно переопределить текущие значения.

    Переопределение индексного файла

    Ситуация: пользователь обратился к каталогу http://www.ваш_домен.ru/price/. При таком запросе первым откроется и будет показан индексный файл. Если вы хотите переопределить индексный файл и сделать так, чтобы первым открывался не index.htm, а файл myindex.php, например. Сделать это можно поместив в файл .htaccess в соответствующем каталоге следующую инструкцию:

    DirectoryIndex myindex.php

    Получив .htaccess с таким содержимым, веб-сервер Apache откроет по умолчанию именно файл myindex.php.

    Паролирование директорий

    Одна из стандартных задач, которая решается путем использования .htaccess, это ограничение доступа к определенному каталогу на сервере. Например, нужно дать доступ к определенному каталогу отдельным посетителям, снабдив их при этом уникальными логином и паролем.

    Создаем в каталоге, к которому хотим ограничить доступ по паролю, файл .htaccess с такими директивами:


    AuthType Basic AuthName "Some Name" AuthUserFile /home/uXXXXX/.htpasswd require valid-user


    Путь /home/uXXXXX/.htpasswd обозначает полный путь к файлу паролей на диске нашего сервера. Если, например, вы поместите файл .htpasswd (в нем будут пароли) в домашний каталог, куда вы попадаете зайдя на сервер по FTP, то путь к этому файлу будет иметь вид /home/uXXXXX/.htpasswd, где uXXXXX - наименование вашей виртуальной площадки (например, u12345).

    В директиве AuthUserFile указываем абсолютный путь к файлу с логинами/паролями, который мы создадим чуть позже. Если вы создаете файл .htaccess на своем компьютере, а не сразу на сервере используя текстовый редактор, обратите особое внимание на то, что .htaccess должен передаваться по FTP строго в текстовом (ASCII) режиме.

    Создаем файл паролей. Файл с паролями должен содержать строки вида login:password. Пароль должен быть зашифрован с использованием алгоритма MD5. Один из способов создать такой файл - воспользоваться программой, входящей в поставку Apache - htpasswd (на нашем сервере она находится в каталоге /usr/local/bin/, полный путь - /usr/local/bin/htpasswd).

    Рассмотрим как создать файл паролей в unix shell прямо на сервере. Зайдем в shell и будем выполнять следующие команды:

    htpasswd -mbc .htpasswd user1 sNQ7j9oR2w - создаем новый файл .htpasswd, в который добавляем запись для пользователя user1 с паролем, указанным в командной строке. Просьба обязательно заменить sNQ7j9oR2w на любой собственный пароль - здесь этот пароль указан только для примера

    htpasswd .htpasswd user2 - добавляем в уже существующий файл .htpasswd пользователя user2, а пароль вводим вручную в ответ на соответствующий запрос программы

    Если вы используете Windows и не хотите пользоваться unix shell для генерации паролей, можно загрузить Windows-версию программы htpasswd здесь и создать файл с паролями на своем компьютере, после чего загрузить его на сервер. Если у вас уже установлена Windows-версия Apache, файл htpasswd.exe можно найти в каталоге Program Files\Apache Group\Apache/bin\.

    Итак, получите htpasswd.exe и используйте его для генерации паролей таким образом:

    htpasswd.exe -mc .htpasswd user1 - создаем новый файл паролей .htpasswd, пароль и его подтверждение будут запрошены интерактивно

    htpasswd.exe -m .htpasswd user2 - добавляем пользователя user2 в существующий файл паролей .htpasswd, запросив пароль интерактивно

    После окончания заведения всех логинов файл нужно загрузить на сервер.

    Собственные страницы ошибок

    Иногда посетители веб-сервера запрашивают страницы, которые по каким-то причинам на сервере не существуют: неправильная ссылка с другой страницы или с другого сайта, владелец сервера случайно удалил документ и так далее. По умолчанию Apache выдает некую довольно аскетичную страницу, на которой находится сообщение вроде "File not found". Вы можете создать альтернативную версию этой страницы, задав обработчик этой ошибки через .htaccess.

    Запрет доступа к некоторым файлам

    Иногда возникает необходимость запретить доступ к определенным файлам. Например, к конфигурационным файлам, содержащим реквизиты доступа к базам данных, интерфейсам и т.п. Допустим, в файле config.cfg вы храните логин/пароль доступа к базе данных. Создаем в этой директории файл .htaccess с директивами:


    Order allow,deny Deny from all


    Теперь, если посетитель наберет в браузере нечто вида http://www.ваш_домен.ru/config.cfg, он получит ошибку ошибку 403 или вашу страницу для этой ошибки.

    Заголовок last-modified

    В ряде случаев требуется, чтобы web-сервер выдавал HTTP-заголовок Last-Modified. К примеру, при регистрации вашего ресурса на Яндексе, возникает ошибка "Неправильные даты".

    Для статических документов, согласно документации по Apache:

    http://httpd.apache.org/docs/mod/mod_include.html#xbithack

    cервер будет выдавать значение last-modified в том случае, если прописана директива "XBitHack full" (просто пропишите эту строку в .htaccess), и для файла, к которому происходит обращение, выставлен атрибут "исполняемый" для группы.
    Это действительно для html-файлов. В скриптах last-modified выдается иными средствами. Например, если учесть то, что php-скрипт генерирует код динамически, то самым логичным будет в качестве last-modified отдавать текущую дату и время. Реализуется это следующим образом:

    ("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");

    Внимание: команда header должна выполняться в php-скрипте до того, как скрипт начнет выдавать html-текст в браузер пользователя.




      панель управления

    User:
    Pass:
    использовать соединение SSL

      Tарифы

    Тариф "Mail"
    Тариф "Kid"
    Тариф "Little"
    Тариф "Real"
    Тариф "Profy"
    Все тарифы
    Регистрация доменов

      Связь

      ОНЛАЙН:
      253885519, 637860  

    (отдел поддержки)
      E-MAIL:
     
    (отдел поддержки)
      ПОЗВОНИТЬ:
      +7(812) 334-12-22

      Принимаем

    Хостинг за WM
    Хостинг за Яндекс.Деньги
    MoneyMail.ru


      Реклама



      Copyright WONET.RU ©  
      WONET Технолоджи 2006