Apache — различия между версиями

Материал из megapuper
Перейти к: навигация, поиск
Строка 57: Строка 57:
 
Правим httpd.conf
 
Правим httpd.conf
 
  <Directory "/usr/local/www/webdav">
 
  <Directory "/usr/local/www/webdav">
                Options Indexes FollowSymlinks MultiViews
 
 
                 Dav On
 
                 Dav On
 
                 <Limit GET POST OPTIONS PROPFIND>
 
                 <Limit GET POST OPTIONS PROPFIND>
Строка 63: Строка 62:
 
                 Allow from all
 
                 Allow from all
 
                 </Limit>
 
                 </Limit>
                Order deny,allow
 
                Allow from all
 
 
                 </Directory>
 
                 </Directory>
 
 
Перегружаем апач и проверяем
 
Перегружаем апач и проверяем
  

Версия 21:06, 28 марта 2014

Подключение php-модуля:

<IfModule mime_module>
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
</IfModule>


Опция Directorylndex показывает, какие файлы нужно выводить пользователю, если он запросил не конкретный файл, а директорию. Данная настройка приведет к тому, что при запросе директории apache сначала будет искать файл index.php, если он будет найден, запустит его и выведет результат выполнения пользователю. Если такого файла нет, то тогда он попытается найти файл index.html. Если и такого файла не найдется, то пользователь получит ошибку. Чтобы не писать в адресе index.php надо добавить его в httpd.conf:

<IfModule dir_module>
DirectoryIndex index.php index.html
</IfModule>


Настройка Basic-auth

Убедиться, что разрешен соответствующий модуль в конфигурации apache в httpd.conf: auth_basic_module Проверям что модуль загружен

# apachectl -M | grep auth_basic_module

Для директории которую будем закрывать добавляем в httpd.conf

<Directory "/usr/local/www/директория">
   AllowOverride AuthConfig
</Directory>

Сохраняем и перечитываем конфиг apachectl graceful

Затем в директории сайта создаём файл .htaccess и пишём туда:

AuthType Basic
AuthName "Enter password"
AuthUserFile /Путь/к/файлу/с/паролями/.htpasswd
AuthGroupFile /dev/null
Require valid-user

В AuthName можно написать свой текст, который выводится наверху окошка при запросе браузером имени пользователя/пароля.
В AuthUserFile прописываем путь к файлу с паролями. Желательно файл с паролями хранить вне пути, доступного через web сервер.


Теперь собственно создаём наш файл паролей. Делаем это с помощью утилитки htpasswd, поставляемой с апачем.

Для создания файла применяем команду:

# htpasswd -с .htpasswd имя_пользователя

Для того, чтоб поменять пароль у уже существующего пользователя достаточно сделать:

# htpasswd .htpasswd имя_пользователя

Не забываем дать права на чтение .htaccess и .htpasswd веб-серверу



Настройка WebDAV

Загружаем модули mod_dav mod_dav_fs

Правим httpd.conf

<Directory "/usr/local/www/webdav">
               Dav On
               <Limit GET POST OPTIONS PROPFIND>
               Order allow,deny
               Allow from all
               </Limit>
               </Directory>

Перегружаем апач и проверяем



Тестирование конфигурации После редактирования конфиг файла стоит проверить, что вы ничего в нем не поломали и все в порядке(по крайней мере с синтаксисом). Для этого можно использовать команду httpd -t. которая считывает конфиг и проверяет его синтаксис.

# httpd -t

Тестирование конфигурации хостов, чтобы просмотреть установки заданные в конфиге. Очень часто ошибки с конфигурацией виртуальных хостов выявляются именно при помощи этой команды.

# httpd -S

apachectl — управление apache сервером

  • apachectl start - запуск
  • apachectl stop - остановка
  • apachectl restart - перезагрузка
  • apachectl graceful - перечитать конфиг без перезагрузки apache