Вернуться   Дизайнерский форум » ВЕБ-ПРОГРАММИРОВАНИЕ » ASP, Perl, PHP и MySQL

Первостепенная защита сайта на PHP

Обсуждение темы Первостепенная защита сайта на PHP в разделе ASP, Perl, PHP и MySQL, часть категории ВЕБ-ПРОГРАММИРОВАНИЕ; Продолжаю изучение защиты сайта. Недавно прочел несколько статей с предложением отключения некоторых функций PHP. Но так как хостинг у меня только виртуальный и ...


Закрытая тема
 
Опции темы
Старый 08.08.2009, 20:21   #1
Продолжаю изучение защиты сайта.

Недавно прочел несколько статей с предложением отключения некоторых функций PHP.
Но так как хостинг у меня только виртуальный и возможности править php.ini нет

Придется править .htaccess
Подскажите, поправте что не так. Что вкл а что выкл ?
Вот несколько директив / функций которые как я понял желательно отключить:


safe_mode
- проверяет владельца запущенного скрипта и если скрипт пытается открыть
какой-либо файл - делает это с правами этого владельца
Код:
php_admin_flag safe_mode on

register_globals
- Запретить создание глобальных переменных из пользовательского ввода

если включена, переменные GET, POST, Cookie, Server будут регистрироваться как глобальные переменные.
Если директива выключена, то глобальный доступ можно получить через массивы $HTTP_ENV_VARS, $HTTP_GET_VARS, $HTTP_POST_VARS, $HTTP_COOKIE_VARS, $HTTP_SERVER_VARS
Код:
php_flag register_globals 0
php_value register_globals 0

allow_url_fopen
- запрет подключению сайта к удалённым страницам, скриптам.
это несколько замедлит работу программы - при каждом вызове *.php скриптов
будет происходить обращение к файлу .htaccess

Код:
	php_value allow_url_fopen 0
	php_flag allow_url_fopen 0

phpinfo
запретить опасные функции:

Код:
disable_functions=phpinfo,system,passthru,cmd

expose_php
- директива сообщает, может ли PHP оповещать пользователей о своем существовании на данном сервере, например, добавляя HTTP заголовок.

Код:
expose_php off

max_filesize
Ограничить размер загружаемого файла на сервер

Код:
upload_max_filesize = 2M

Ограничения на время работы
Код:
max_execution_time = 30

Отключить вывод ошибок
И включить директиву записи ошибок в лог-файл сервера.

В результате такого запроса, становится известен путь к скрипту и имя файла.
Если нет доступа к php.ini, можно добавить в начало скрипта строку error_reporting(0); это подавит вывод ошибок.

Код:
php_flag display_errors off
php_flag log_errors on
php_value error_log /home/ваш_путь/web/php_error.log
php_value error_reporting 2039

magic_quotes_gpc
- если включена, автоматически добавляет слеши к данным пришедшим от пользователя - из POST, GET запросов и cookie.

Код:
php_flag magic_quotes_gpc 0

magic_quotes_runtime
- если включена, автоматически добавляет слеши к данным, полученным во время исполнения скрипта - например, из файла или базы данных.
Код:
php_flag magic_quotes_runtime 0

Под вопросом:
php_value magic_quotes_sybase Off
php_value post_max_size 20M
php_value max_input_time 200


PS
Немного запутался в следующем:
1. safe_mode должен быть выключен или выключен?
2. функции должны включатся с помощью php_value или php_flag ? - поэтому некоторые примеры представлены в разных(двух) вариантах.
3. как включить некоторые функции в htaccess мне не удалось узнать поэтому они написаны в виде настроек для php.ini
 
Старый 08.08.2009, 20:21
Ссылки
Старый 08.08.2009, 20:36   #2
1. Выключен
2. Потому что значения у параметров бывают двух типов: флаги и не флаги (текст, числа etc)
 
Старый 08.08.2009, 21:19   #3
Цитата:
Сообщение от deMone Посмотреть сообщение
2. Потому что значения у параметров бывают двух типов: флаги и не флаги (текст, числа etc)
Как будет правильней сделать?
 
Старый 11.08.2009, 00:33   #4
blacks, у вас есть сервер-копия вашего основного сервера, с включенным отображением ошибок, включенным phpinfo и пр.?
 
Старый 11.08.2009, 01:03   #5
Цитата:
Сообщение от kost Посмотреть сообщение
blacks, у вас есть сервер-копия вашего основного сервера, с включенным отображением ошибок, включенным phpinfo и пр.?
Немного Вас не понял.

Логи смотреть могу.
phpinfo тоже (как раз этим сейчас занимаюсь)
 
Старый 11.08.2009, 21:33   #6
Устанете разрабатывать, отключив все на сервере. На боевой машине имеет смысл.
 
Старый 11.08.2009, 21:33
Закрытая тема




Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Защита сайта от спама bart Кальянная 3 20.09.2008 22:21
Защита ActionScript andrey61 Технологии Flash 1 12.02.2006 22:58
защита от хакеров gatto ASP, Perl, PHP и MySQL 5 04.04.2005 14:45
Защита сайта паролем Spy HTML, CSS, JavaScript 1 20.05.2003 15:48


Текущее время: 03:58. Часовой пояс GMT +4.

Реклама на форуме Условия размещения рекламы
Биржа ссылок Заработай на сайте!
Дизайнерский форум