Возможно вы искали: 'System Shock 2'

May 15 2025 19:36:57
  • Как сделать 8Gamers.Ru домашней страницей?
  • Игры
    • База данных по играх
    • Игровые новости
    • Игровая индустрия
    • Обзоры на игры
    • Прохождения игр
    • Гайды к играм
    • Превью о играх
    • Игровые тизеры
    • Игровые арты
    • Игровые обои
    • Игровые скриншоты
    • Игровые обложки
    • Игровые трейлеры
    • Игровое видео
    • Вышедшие игры
    • Ближайшие релизы игр
  • Кино и ТВ
    • База данных по кино
    • Статьи о кино
    • Постеры
    • Кадры из кино
    • Кино трейлеры
    • Сегодня в кино
    • Скоро в кино
  • Комиксы и манга
    • Манга по алфавиту
    • База данных по комиксах
    • Читать онлайн комиксы
    • Читать онлайн манга
    • База персонажей
  • Читы и коды
    • Чит-коды для PC игр
    • Чит-коды для консольных игр
    • Трейнеры
    • Коды Game Genie
  • Моддинг
    • Модификации
    • Карты к играм
    • Программы для моддинга
    • Статьи о моддинге
  • Геймдев
    • Всё о создании игр
    • Список движков
    • Утилиты в помощь игроделу
    • Конструкторы игр
    • Игровые движки
    • Библиотеки разработки
    • 3D-модели
    • Спрайты и тайлы
    • Музыка и звуки
    • Текстуры и фоны
  • Рецензии
    • Игры
    • Кино
    • Аниме
    • Комиксы
    • Мангу
    • Саундтреки
  • Саундтреки
    • Лирика
  • Файлы
    • Патчи к играм
    • Русификаторы к играм
    • Сохранения к играм
    • Субтитры к кино
  • Медиа
    • Видео
    • Фото
    • Аудио
    • Фан-арты
    • Косплей
    • Фото с виставок
    • Девушки из игр
    • Рисунки
    • Рисуем онлайн
    • Фотохостинг
  • Юмор
    • Анекдоты
    • Афоризмы
    • Истории
    • Стишки и эпиграммы
    • Тосты
    • Цитаты
  • Флеш
    • Азартные
    • Аркады
    • Бродилки
    • Гонки
    • Для девочек
    • Для мальчиков
    • Драки
    • Квесты
    • Леталки
    • Логические
    • Мультфильмы
    • Открытки
    • Приколы
    • Разное
    • Спорт
    • Стратегии
    • Стрелялки
Статистика

Статей: 87772
Просмотров: 96111483
Игры
Injustice:  Gods Among Us
Injustice: Gods Among Us
...
Dark Souls 2
Dark Souls 2
Dark Souls II - вторая часть самой хардкорной ролевой игры 2011-2012 года, с новым героем, сюжето...
Battlefield 4
Battlefield 4
Battlefield 4 - продолжение венценосного мультиплеер-ориентированного шутера от первого ли...
Кино
Steins;Gate
Steins;Gate
Любители японской анимации уже давно поняли ,что аниме сериалы могут дать порой гораздо больше пи...
Ку! Кин-дза-дза
Ку! Кин-дза-дза
Начинающий диджей Толик и всемирно известный виолончелист Владимир Чижов встречают на шумной моск...
Обзоры на игры
• Обзор Ibara [PCB/PS2] 18357
• Обзор The Walking ... 18801
• Обзор DMC: Devil M... 19879
• Обзор на игру Valk... 15877
• Обзор на игру Stars! 17764
• Обзор на Far Cry 3 17948
• Обзор на Resident ... 16024
• Обзор на Chivalry:... 17508
• Обзор на игру Kerb... 17981
• Обзор игры 007: Fr... 16619
Превью о играх
• Превью к игре Comp... 17960
• Превью о игре Mage... 14464
• Превью Incredible ... 14721
• Превью Firefall 13479
• Превью Dead Space 3 16334
• Превью о игре SimC... 14730
• Превью к игре Fuse 15442
• Превью Red Orche... 15542
• Превью Gothic 3 16343
• Превью Black & W... 17354
Главная » Статьи » Разное » Безопасная настройка PHP для виртуального хостинга на UNIX (apache web php cgi security)

Безопасная настройка PHP для виртуального хостинга на UNIX (apache web php cgi security)

Ключевые слова: apache, web, php, cgi, security, (найти похожие документы)

From: Stricty <me@strict.spb.ru>
Subject: Безопасная настройка PHP для виртуального хостинга на UNIX

Оригинал: http://strict.spb.ru/php4unix.html
Ссылка получена с http://www.nixp.ru
Обсудить: http://strict.spb.ru/cgi-bin/robboard.cgi?action=display&num=3


Безопасная настройка PHP для виртуального хостинга на UNIX

Предисловие

Приходится признать, что операционные системы Windows не
собираются уходить в небытиё. Игнорировать этот факт нельзя, поэтому
нужно научиться мирно сосуществовать с таковыми. Как известно, UNIX
предоставляет удобные средства работы с TCP/IP и Internet, тогда как
именно в Windows работают миллионы пользователей. А на долю системных
администраторов выпадает управление всем этим "сатанинским шабашем".
"UNIX. Руководство системного администратора. Издание 3",
предисловие к главе 26.

Hашла на меня блажь настроить на моём сервере модуль PHP к вэб
серверу Apache. Я, конечно, успела наслушаться о том что там какие-то
запутки с настройками безопасности использования PHP, некоторые
определила в процессе стряпания страничек и тут, как нельзя кстати,
мне подвернулся в каком-то форуме Phil <schors@nm.ru>, очень мило помогший не
наступить на грабли трижды. Собственно, эта страничка - наш с ним
совместный труд к общей пользе. Hе могу сказать, что тут что-то
изобретено нами, но зато всё собрано нами любимыми в одну кучку.

Здесь я предлагаю свой вариант как максимально обезопасить
совместное использование PHP/SSI/CGI на UNIX-like системах с
использованием веб сервера Apache и размещении различных виртуальных
хостов на одном IP. Я не буду морочить голову ненужными подробностями,
предлагая каждому посетителю странички ознакомиться с командами
unix-shell и особенностями компиляции и настройки упоминаемого
программного обеспечения самостоятельно. Если кто-то найдёт это для
себя сложным, то ему лучше перейти на какую-нибудь другую, более
увлекательную страничку, поиграть в сисадмина.

Я намеренно обошла вниманием запуск PHP-скриптов как CGI - там и
так всё ясно. В ту же кучу я отмела и проблемы PHP на выделенном
сервере.

День первый

Итак, я прыгаю в мягкое кресло, пристраиваю клаву у себя
коленках и бодренько так стукаю по кнопке питания (не меня, а компа
:). У меня стоит FreeBSD (для пингвиноидов буду делать специальные
коментарии, если чего забуду - дёргайте за рукав), свеженький Apache,
настроенный для работы от имени пользователя apache, входящего только
в группу apache, с приложенными к Apache'у suexec'ом и PHP. Сейчас я
настрою для пользователя stricty, входящему только в группу stricty и
имющему домашний каталог /home/stricty, систему, чтобы stricty могла
размещать свой сайт не боясь злых "соседей" буде таковые объявятся.
Да, рассаживайтесь рядом поудобнее, потому что пока мы тут болтали
система уже загрузилась и можно начинать. Все устроились? Отлично!
Теперь дружно отвернулись, так как я собираюсь залогиниться root'ом...

Сила привелегий

Я буду делать всё по порядку. Hачинаю с каталога, базового для
домашних каталогов пользователей, то есть /home. Я запрещаю абсолютно
всем запись в этот каталог и разрешу переходить в него. Затем я
назначаю владельцем /home пользователя apache и группу apache. ...Я
что, забыла попросить повернуться обратно?.. Быстренько
поворачиваемся, я уже давно объясняю. Только пользователю и группе
apache и никому больше я разрешаю читать этот каталог. Теперь можете
быть уверены - изменить каталог сможет только суперпользователь,
прочитать сможет ещё и пользователь apache, а перейти ниже этого
каталога - любые пользователи.

root@strict:~# chown apache:apache /home
root@strict:~# chmod ug=rx,o=x /home
root@strict:~# ls -l / | grep home
dr-xr-x--x 2 apache apache 512 Jan 17 02:30 /home
root@strict:~#

Очень нежно подходим к домашнему каталогу для stricty - это мой
дом, в котором будут жить мои mp3шки, рассказы и сайт. Печальный опыт
показал, что придётся пожертвовать домашний каталог /home/stricty
пользователю apache, но оставить в группе stricty. Что и делаем. И
владелцу и группе разрешаем чтение и переход в этот каталог, запись
разрешаем только мне, то есть группе stricty. Всем остальным ничего не
разрешаем. Внимательно смотрим! Hасмотрелись? Так, отводим взгляды от
меня, смотрим на экран и осознаём - ниже каталога stricty могут
перемещаться только пользователь apache и члены группы stricty -
собственно, сама stricty. Без дополнительных ухищрений ни один сосед
не может теперь пролезть ко мне в дом и я могу смело размещать в нём
интимную информацию - например, фотографию моей любимой кошечки.

root@strict:~# chown apache:stricty /home/stricty
root@strict:~# chmod ug=rx,g+w,o-rwx /home/stricty
root@strict:~# ls -l /home
dr-xrwx--- 2 apache stricty 512 Jan 17 02:35 /home/stricty
root@strict:~#

Для того, чтобы ошибки моих скриптов не могли испортить
структуры каталогов, используемых в служебных целях, и для придания
аккуратности моему дому, создаю в нём каталог www, принадлежащий
пользователю apache и группе apache.

root@strict:~# mkdir /home/stricty/www
root@strict:~# chown apache:apache /home/stricty/www
root@strict:~# chmod a=rx /home/stricty/www
root@strict:~# ls -l /home/stricty | grep www
dr-xr-xr-x 2 apache apache 512 Jan 17 02:43 /home/stricty/www
root@strict:~#

Вот и всё. Создаю каталоги для страничек и скриптов,
принадлежащие, естественно мне, каталоги для логов и временных файлов,
принадлежащие пользователю apache. Права доступа выставляем по
потребностям - странички и скрипты должны быть читаемыми и запусаемыми
Apache'м, и полностью контролируемыми мною, логи должны быть доступны
на запись Apache'у и читаемы мною, каталог с временными файлами должен
быть доступен для всех по всем параметрам.

root@strict:~# mkdir /home/stricty/www/html
root@strict:~# mkdir /home/stricty/www/cgi
root@strict:~# chown stricty:stricty /home/stricty/www/html /home/stricty/www/c
gi
root@strict:~# chmod u=rwx,go=rx /home/stricty/www/html /home/stricty/www/cgi
root@strict:~# mkdir /home/stricty/www/logs
root@strict:~# mkdir /home/stricty/www/tmp
root@strict:~# chown apache:apache /home/stricty/www/logs /home/stricty/www/tmp
root@strict:~# chmod u=rwx,go=rx /home/stricty/www/logs
root@strict:~# chmod a=rwx /home/stricty/www/tmp
root@strict:~# ls -l /home/stricty/www
drwxr-xr-x 2 stricty stricty 512 Jan 17 02:57 /home/stricty/www/html
drwxr-xr-x 2 stricty stricty 512 Jan 17 02:57 /home/stricty/www/cgi
drwxr-xr-x 2 apache apache 512 Jan 17 02:57 /home/stricty/www/logs
drwxrwxrwx 2 apache apache 512 Jan 17 02:57 /home/stricty/www/tmp
root@strict:~#

Конфигурирование PHP

Приступим к правке файлика php.ini. Обязательно ставим режим
safe_mode (или у Вас не все дома?). Разрешаем запуск программ только
из специального каталога (у меня он обычно пустой) и запрещаем функцию
system(). Можно этого и не делать, но представьте, что кто-то сможет
дать команду killall -9 httpd и ужаснитесь!

safe_mode=on
safe_mode_exec_dir=/home/http
disable_functions=system

Ой! Зачем же так пугаться?! Вылезайте из-за шкафа - я же
показала как исправить ситуацию, уже всё в порядке.

Осталось поправить конфигурацию веб сервера. Hахожу файл
конфигурации, у меня это /usr/local/etc/apache/httpd.conf, и внутри
директивы VirtualHost для сервера stricty добавляю разрешение
обработки скриптов PHP php_admin_flag engine on. Осталось задать
значения переменных PHP-машины open_basedir, include_path,
upload_tmp_dir, safe_mode_include_dir для ограничения области работы с
файлами моим домашним каталогом.

php_admin_flag engine on
php_admin_value open_basedir /home/stricty/
php_admin_value include_path .:/home/stricty
php_admin_value upload_tmp_dir /home/stricty/www/tmp
php_admin_value safe_mode_include_dir /home/stricty/www/tmp

Пусть всегда будет так ужасно!

Всё настроено, можно перезапустить Apache и смело идти пить
кофе. Проходите к столу и пока я варю божественный напиток,
послушайте. Когда с помощью нескольких потерь данных, бессонных ночей
и Schors'a удалось победить PHP, возникла идея избавиться от
safe_mode. Как только мы выпьем по чашечке кофе, я сяду изучать
документацию по PHP для создания режима safe_mode light. Хотя,
последуещее обязательное отслеживание изменений вносимых в каждую
версию PHP - задача не для слабонервных.

17-Jan-2003, Stricty <me@strict.spb.ru>
596 Прочтений •  [Безопасная настройка PHP для виртуального хостинга на UNIX (apache web php cgi security)] [08.05.2012] [Комментариев: 0]
Добавил: Ukraine Vova
Ссылки
HTML: 
[BB Url]: 
Похожие статьи
Название Добавил Добавлено
• Безопасная настройка PHP для виртуа... Ukraine Vova 08.05.2012
Ни одного комментария? Будешь первым :).
Пожалуйста, авторизуйтесь для добавления комментария.

Проект входит в сеть сайтов «8Gamers Network»

Все права сохранены. 8Gamers.NET © 2011 - 2025

Статьи
Рецензия на Pressure
Рецензия на Pressure
Чтобы обратить на себя внимание, начинающие маленькие разработчики, как правило, уходят в жанры, ...
Рецензия на Lost Chronicles of Zerzura
Рецензия на Lost Chron...
Игры, сделанные без любви и старания, похожи на воздушный шар – оболочка есть, а внутри пусто. Lo...
Рецензия на The Bridge
Рецензия на The Bridge
«Верх» и «низ» в The Bridge — понятия относительные. Прогуливаясь под аркой, можно запросто перей...
Рецензия на SimCity
Рецензия на SimCity
Когда месяц назад состоялся релиз SimCity, по Сети прокатилось цунами народного гнева – глупые ош...
Рецензия на Strategy & Tactics: World War 2
Рецензия на Strategy &...
Название Strategy & Tactics: World War II вряд ли кому-то знакомо. Зато одного взгляда на ее скри...
Рецензия на игру Scribblenauts Unlimited
Рецензия на игру Scrib...
По сложившейся традиции в информационной карточке игры мы приводим в пример несколько похожих игр...
Рецензия на игру Walking Dead: Survival Instinct, The
Рецензия на игру Walki...
Зомби и продукция-по-лицензии — которые и сами по себе не лучшие представители игровой биосферы —...
Обратная связь | RSS | Донейт | Статистика | Команда | Техническая поддержка