Капча на PHP и JavaScript
Создавая сайты разной сложности, практически всегда встает вопрос в защите его от заваливания нежелательными комментариями или автоматическими регистрациями. От части эту проблему можно решить с помощью установки скрипта CAPCHA. Если сайт разрабатывается на популярной CMS типа WordPress, Joomla или Drupal то проблем с этим возникнуть не должно, достаточно просто найти подходящий плагин и просто установить его. Но, что делать если сайт целиком пишется на собственной CMS? (замечу, что предложенный мною вариант также пригоден для любой CMS)
Поиски в интернете, на популярных блогах и сайтах посвященных программированию я не нашел такого скрипта который было бы легко интегрировать в любую систему. а если и попадались варианты, то все они были либо платными, либо работали не совсем так как мне хотелось бы.
В результате я написал свой небольшой скрипт на PHP. Алгоритм его работы следующий:
- на странице где необходимо вставить форму отображения и ввода кода, вставляется JS код, который генерирует картинку с кодом.
- скрипт на PHP генерирует код и сохраняет его во временный файл.
- после отправки пользователем формы с введенным кодом проверки, скрипт принимает введенное значение и сравнивает с кодом хранившемся во временном файле.
Как видите принцип работы очень прост. Рассмотрим сам код:
файл размещаем в корневой директории сайта, capcha.php
<!-- \');'; echo 'document.write(\'<! \');'; echo 'document.write(\'.capcha {color: #000; font-size:20px; background-color: #C1E2EC; width: 65px; text-align: center;}\');'; echo 'document.write(\'-->\');'; echo 'document.write(\' -->\');'; $dest=rand(1000,9999); // Генерируем код, который будет выведен на картинке для ввода пользователем $capid=rand(1000,9999); // Генерируем ID для временного файла, чтобы скрипт знал с чем сравнивать введенный код echo "document.write('<input name="\"capid\"" type="\"hidden\"" value="\"$capid\"" />Введите код с картинки: <span>*</span> <span class="\'capcha\'">$dest</span>');"; // Записываем сгенерированный код во временный файл $filename = 'tmp/capcha'.$capid.'.cache'; $fh = fopen($filename, "w"); $success - fwrite($fh, $dest); fclose($fh); ?> |
В форму где необходимо вывести код капчи вставляем HTML код:
<script charset="utf-8" type="text/javascript" src="./capcha.php"></script> <input type="text" name="cap" required /> |
В файл в который будут передаваться данные из формы вставляем следующий код:
$cap=htmlspecialchars(strip_tags($_POST['cap'])); // получаем введенный код $uplink='tmp/capcha'.$_POST['capid'].'.cache'; $fh = @fopen($uplink, "rb"); $data = @fread($fh, filesize($uplink)); // считываем сохраненный код из временного файла @fclose($fh); @unlink($uplink); if ($cap<>$data){ // сравниваем введенное значение с сохраненным, в случае ошибки выводим сообщение и прекращаем работу скрипта echo '<script language="JavaScript"> alert(\'Неверно введен проверочный код с картинки!. \'); window.location.href = "http://all-alliance.ru/component/content/article/40-dom/'.$red.'-add" </script>'; exit; } |
Также на корневой директории сайта должна быть папка tmp с выставленными правами на запись 777.
данный скрипт очень прост в применении. Разумеется это лишь демонстрация алгоритма работы подобной защиты от спам-ботов и т.д. Вы можете с легкостью доработать его на своем усмотрение.
Похожие записи
Оставить комментарий
- Перенести ли домены с Рег.ру на Бегет? спросил (а) Виктор
- RuCaptcha bot и бан по IP спросил (а) Родмик
- MySQL запрос с несколькими JOIN спросил (а) Александр
- MySQL выбрать данные из двух таблиц спросил (а) Виталий
- Редирект при переносе сайта на WordPress спросил (а) Николай
- Интеграция сайта со СДЭК по API к записи
- Интеграция сайта со СДЭК по API к записи
- PHP. Кириллица в регулярных выражениях к записи
- Скрипт постраничной навигации (расширенная версия) к записи
- Прогон сайта по профилям, стоит ли? к записи
- Парсинг телефонов с Авито к записи
- Прогон сайта по профилям, стоит ли? к записи
Archive
- +2020 (20)
- Декабрь 2020 (6)
- Сентябрь 2020 (2)
- Август 2020 (1)
- Июль 2020 (2)
- Май 2020 (2)
- Апрель 2020 (2)
- Март 2020 (2)
- Февраль 2020 (1)
- Январь 2020 (2)
- +2019 (18)
- Декабрь 2019 (3)
- Ноябрь 2019 (2)
- Октябрь 2019 (2)
- Сентябрь 2019 (1)
- Август 2019 (2)
- Июль 2019 (1)
- Июнь 2019 (1)
- Апрель 2019 (2)
- Март 2019 (1)
- Февраль 2019 (3)
- +2018 (44)
- Декабрь 2018 (4)
- Ноябрь 2018 (7)
- Октябрь 2018 (8)
- Сентябрь 2018 (1)
- Август 2018 (4)
- Июль 2018 (5)
- Май 2018 (3)
- Апрель 2018 (7)
- Март 2018 (1)
- Февраль 2018 (2)
- Январь 2018 (2)
- +2017 (19)
- Декабрь 2017 (2)
- Ноябрь 2017 (1)
- Октябрь 2017 (1)
- Сентябрь 2017 (2)
- Июль 2017 (1)
- Июнь 2017 (1)
- Май 2017 (2)
- Апрель 2017 (3)
- Март 2017 (2)
- Февраль 2017 (1)
- Январь 2017 (3)
- +2016 (37)
- Декабрь 2016 (3)
- Ноябрь 2016 (3)
- Октябрь 2016 (2)
- Сентябрь 2016 (3)
- Август 2016 (7)
- Июнь 2016 (3)
- Май 2016 (3)
- Апрель 2016 (3)
- Март 2016 (1)
- Февраль 2016 (1)
- Январь 2016 (8)
- +2015 (36)
- Ноябрь 2015 (5)
- Октябрь 2015 (4)
- Сентябрь 2015 (1)
- Август 2015 (8)
- Июнь 2015 (1)
- Май 2015 (4)
- Апрель 2015 (8)
- Март 2015 (3)
- Февраль 2015 (2)
- +2014 (26)
- Ноябрь 2014 (2)
- Октябрь 2014 (5)
- Сентябрь 2014 (6)
- Июль 2014 (1)
- Июнь 2014 (2)
- Май 2014 (3)
- Апрель 2014 (6)
- Февраль 2014 (1)
- +2013 (27)
- Декабрь 2013 (2)
- Ноябрь 2013 (1)
- Октябрь 2013 (1)
- Август 2013 (1)
- Июль 2013 (3)
- Июнь 2013 (10)
- Май 2013 (1)
- Апрель 2013 (2)
- Февраль 2013 (3)
- Январь 2013 (3)
- +2012 (42)
- Декабрь 2012 (2)
- Ноябрь 2012 (3)
- Октябрь 2012 (7)
- Сентябрь 2012 (2)
- Август 2012 (1)
- Июль 2012 (3)
- Июнь 2012 (2)
- Май 2012 (6)
- Апрель 2012 (2)
- Март 2012 (8)
- Февраль 2012 (5)
- Январь 2012 (1)
- +2011 (57)
- Декабрь 2011 (6)
- Ноябрь 2011 (2)
- Октябрь 2011 (3)
- Сентябрь 2011 (5)
- Август 2011 (4)
- Июль 2011 (3)
- Июнь 2011 (3)
- Май 2011 (3)
- Апрель 2011 (4)
- Март 2011 (10)
- Февраль 2011 (5)
- Январь 2011 (9)
- +2010 (43)
- Декабрь 2010 (7)
- Ноябрь 2010 (21)
- Октябрь 2010 (14)
- Сентябрь 2010 (1)
Свежие записи
- Регистрация программы для ЭВМ или базы данных в Роспатенте 27.12.2020
- Парсер для форума XenForo 22.12.2020
- Интеграция Тинькофф банк Эквайринг на сайт для приема платежей 18.12.2020
- PHP скрипт для проведения акций с призами на сайте(автоматизированный маркетинг) 16.12.2020
- Скрипт калькулятора емкости HDD для видеонаблюдения 03.12.2020

