Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Защита от запуск скрипта по прямой ссылке

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
ivanviar
Отправлено: 12 Июня, 2015 - 15:46:03
Post Id


Новичок


Покинул форум
Сообщений всего: 2
Дата рег-ции: Июнь 2015  


Помог: 0 раз(а)




Добрый день,
Возможно вопрос банальный, но я уже изгуглился и решения не нашел.
Есть скрипт, который принимает параметры и отправляет письмо на админский ящик - принимает заявку, проще говоря.
/cgi-bin/contact.php, который может быть запушен, к примеру, с параметром ?message=Hello

Этот скрипт вызывается при сабмите формы на сайте.

Я вижу дыру в безопасности, что любой может напрямую обращаться к моему скрипту и завалить ящик:
[цикл - отправлять раз в секунду весь день]
sitename.ru/cgi-bin/contact.php?message="Купите гербалайф"
[конец цикла]

Вопрос: как сделать так, чтобы скрипт мог запускаться только из формы?

Пока придумал в сессии хранить некое значение, которое проверять в скрипте:
$_SESSION["sendmail_pass"]="123"
Но после первого запуска из формы, сессия, понятно в браузере сохраняется и можно переходить к прямым обращениям к скрипту.

Я дополнил решение еще одной переменной в сессии, ограничивающей количество писем из одной сессии - пятью.

В принципе, это меня устраивает, но мне это решение кажется "немного через задницу" Улыбка

Может есть какой-то проверенный способ?

Заранее спасибо.

Иван

(Отредактировано автором: 12 Июня, 2015 - 15:47:25)

 
 Top
likvidator
Отправлено: 12 Июня, 2015 - 16:07:37
Post Id


Посетитель


Покинул форум
Сообщений всего: 416
Дата рег-ции: Март 2012  


Помог: 4 раз(а)

[+]


если есть авторизация,аля админка,то проверяй авторизован ли username и имеет ли права
 
 Top
ivanviar
Отправлено: 12 Июня, 2015 - 16:10:46
Post Id


Новичок


Покинул форум
Сообщений всего: 2
Дата рег-ции: Июнь 2015  


Помог: 0 раз(а)




likvidator пишет:
если есть авторизация,аля админка,то проверяй авторизован ли username и имеет ли права

Нет, авторизации нет. Нужно, чтобы заявку мог оставить любой неавторизованный пользователь, но только через форму с капчей.
 
 Top
DeepVarvar Супермодератор
Отправлено: 12 Июня, 2015 - 16:11:42
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Не, у тебя в целом размышления верные.
Со временем и практикой сам додумаешь как это все делать чтоб удобно и быстро было.
А щас оставляй как есть.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB