Модераторы: skyboy, MoLeX, Aliance, ksnk

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Защита от подбора пароля? 
:(
    Опции темы
korob2001
Дата 19.5.2004, 14:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2871
Регистрация: 29.12.2002

Репутация: 1
Всего: 61



Я как-то писал на Perl сайт с администрированием. На страничке административного входа была форма, состоящая из двух текстовых полей(логин, пароль), одного выпадающего меню (секретный цвет) и, конечно же, кнопки Submit.
Так как вход предназначен только для администратора и мне не хотелось бы чтобы кто-нибудь получил пароль доступа , я решил написать такой вариант защиты от брутфорса:

1. Если никаких параметров не передано, скрипт генерит форму.


2.
a.) Если получены параметры, то сверяем логин, пароль и цвет. Если хоть что-нибудь не совпало, то открываем текстовый файл и записываем туда 1 ( при каждой последующей неудачной попытке, просто инкерементируем число в файле). Затем сверяем число с тем, которое было указано в настройках в переменной. Если числа равны, то прога генерирует случайную строку (из 150 символов), затем записывает эту строку в файл, где хранилось число попыток и затем переименовывает сама себя, при этом изменяя права доступа на саму себя chmod 0600. Новое имя и есть ранее сгенеринная строка (которую мы записали в файл).
b.) Если всё верно, то переходим на нужную страничку, которая в свою очередь проверяет откуда были переданы параметры. Если параметры переданы не с нашего скрипта, тогда генерим ошибку. Если с нашего, то всё нормально и прога приветствует администратора.

3. Затем написал ещё один маленький скрипт ( не CGI ). Его задачей было проверить файл где мы храним кол-во неверных попыток входа.
a.) Если в файле записано не число, то сверяем время последнего изменения файла и текущее время. Если timeout ( который мы установили в фале конфигурации ) истёк, значит программа выдёргивает из этого файла новое имя нашего первого скрипта. После переименовывает наш первый скрипт в его нормальное имя и меняет права доступа.
б.) Если в файле оказалось число и timeout истёк, обнуляем число в фале где хранилось кол-во неудачных попыток. Если же timeout не истёк и в файле число, то просто завершаем работу скрипта.

Второй скрипт запускался из cron'a. Если cron не доступен, значит придётся время от времени запускать его ручками.

Ну вот, вроде всё. Но такой вариант подойдёт только для странички входа админа.
Преимущество в том, что мы имеем самоисчезающие ворота. Для взломщика самое худшее, когда, на его глазах, дверь исчезает. ;)
Недостаток - скрипт на время становится не доступен.

Удачи.

Это сообщение отредактировал(а) korob2001 - 19.5.2004, 14:11


--------------------
"Время проходит", - привыкли говорить вы по неверному пониманию. 
"Время стоит - проходите вы".
PM MAIL WWW ICQ MSN   Вверх
Павел
Дата 6.7.2004, 11:36 (ссылка)    |    (голосов: 0) Загрузка ... Загрузка ... Быстрая цитата Цитата


Unregistered











А если использовать проверку нажата ли кнопка submit с таким-то именем. Если да то проверяет значения, если нет то выкидывает. Как думаете подойдет это?
  Вверх
Secandr
Дата 6.7.2004, 17:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Связист
****


Профиль
Группа: Экс. модератор
Сообщений: 4043
Регистрация: 3.8.2003
Где: Russia, Volgograd

Репутация: 5
Всего: 39



а как пользователь узнает какое имя нужно нажать?


--------------------
Мышки плакали, кололись, но продолжали жрать кактусы (с) cisco
PM ICQ AOL   Вверх
Павел
Дата 6.7.2004, 20:12 (ссылка)    |    (голосов: 0) Загрузка ... Загрузка ... Быстрая цитата Цитата


Unregistered











Нет ты не понял!

.....
<input type="submit" name="ok" value="Старт">
......


Вот и в файле идет проверка:
if(@$ok)
{
......
}
else
{
echo "Защита";
}

  Вверх
Павел
Дата 6.7.2004, 20:16 (ссылка)    |    (голосов: 0) Загрузка ... Загрузка ... Быстрая цитата Цитата


Unregistered











а лучше в name сделать типа что-то date() на минуты в md5 и будет проверка. Я думаю вы меня поняли.

Тоесть если в этот год в этот месяц и в этот день и в этот час и в эту минуты была нажата кнопка то все путем.

Промохнуться можно только тогда, когда пользоваетль нажал на кнопку в 59 секунд а попал туда в 60 секунд тоесть прошла минута.
  Вверх
Secandr
Дата 6.7.2004, 22:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Связист
****


Профиль
Группа: Экс. модератор
Сообщений: 4043
Регистрация: 3.8.2003
Где: Russia, Volgograd

Репутация: 5
Всего: 39



так я тебе соченю хттп запрост так, что скрипт не отличит нажал я кнопку или это моя программа прислала запрос


--------------------
Мышки плакали, кололись, но продолжали жрать кактусы (с) cisco
PM ICQ AOL   Вверх
Guest
Дата 7.7.2004, 08:46 (ссылка)    |    (голосов: 0) Загрузка ... Загрузка ... Быстрая цитата Цитата


Unregistered











А через сессию как-нить можно защититься тогда?
  Вверх
Secandr
Дата 7.7.2004, 13:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Связист
****


Профиль
Группа: Экс. модератор
Сообщений: 4043
Регистрация: 3.8.2003
Где: Russia, Volgograd

Репутация: 5
Всего: 39



нет.
можно генерировать картинку или цвет или слово, запоминать её в бд, а потом проверять.


--------------------
Мышки плакали, кололись, но продолжали жрать кактусы (с) cisco
PM ICQ AOL   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "PHP"
Aliance
IZ@TOP
skyboy
SamDark
MoLeX

Новичкам:

  • PHP редакторы собираются и обсуждаются здесь
  • Электронные книги по PHP, документацию можно найти здесь
  • Интерпретатор PHP, полную документацию можно скачать на PHP.NET

Важно:

  • Не брезгуйте пользоваться тегами [code=php]КОД[/code] для повышения читабельности текста/кода.
  • Перед созданием новой темы воспользуйтесь поиском и загляните в FAQ
  • Действия модераторов можно обсудить здесь

Внимание:

  • Темы "ищу скрипт", "подскажите скрипт" и т.п. будут переноситься в форум "Web-технологии"
  • Темы с именами: "Срочно", "помогите", "не знаю как делать" будут УДАЛЯТЬСЯ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, IZ@TOP, skyboy, SamDark, MoLeX, awers.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0872 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.