Как я сделал голосование через каптчу ( recaptcha в форме виджета vote up down )

Аватар пользователя iehon iehon 30 ноября 2011 в 1:58

C самого начала конкурсов на семейном сайте rodnulechka63.ru начали происходить накрутки. Мы в свою очеред начали бороться с ними. Одним из решений было добавление каптчи в голосование. На друпал.ру и .орг не нашел решений, поэтому делалось все долго и мучительно. Т.к. с php я мало знаком :)

Итак, приступим.

1. идем на recaptcha и указываем свой сайт -> получаем ключи publickey privatekey (их надо будет прописать в файл вывода виджета widget.tpl.php в п.3)

2. закачиваем файл recaptchalib.php в корень сайта. Берем его отсюда http://code.google.com/p/recaptcha/downloads/list?q=label:phplib-Latest

3. правим файл стиля голосовалки модуля vote_up_down\widgets\alternate\widget.tpl.php

привожу код моего файла целиком

<?php
// $Id: widget.tpl.php,v 1.1.2.18 2010/12/05 07:50:06 marvil07 Exp $
/**
 * file
 * widget.tpl.php
 *
 * Alternate widget theme for Vote Up/Down
 */

?>
<script type="text/javascript">var RecaptchaOptions = {  
lang : 'ru',
theme : 'white',
tabindex : 1,
};</script>
<div class="vud-widget vud-widget-alternate" id="<?php print $id; ?>">
  <?php
if ($class_up) :
 ?>
    <?php print "Голосов: $unsigned_points"; ?>
    <?php if ($show_links): ?>
      <?php if ($show_up_as_link): ?>
       
      <?php endif; ?>
<form action="" method="post">
<?php
require_once('recaptchalib.php');
// Get a key from https://www.google.com/recaptcha/admin/create
$publickey = "Возлюби Господа Бога твоего всем сердцем твоим";
$privatekey = "Возлюби ближнего твоего_как самого себя";
# the response from reCAPTCHA
$resp = null;
# the error code from reCAPTCHA, if any
$error = null;
# was there a reCAPTCHA response?
if ($_POST["recaptcha_response_field"]) {
        $resp = recaptcha_check_answer ($privatekey,
                                        $_SERVER["REMOTE_ADDR"],
                                        $_POST["recaptcha_challenge_field"],
                                        $_POST["recaptcha_response_field"]);
        if ($resp->is_valid) {
                echo "Проверка на спам-накрутку пройдена, теперь вы можете ";

echo "<a href=";
print $link_up;
echo "><br><font size=+1>Проголосовать!(нажмите на ссылку)</font></a><br>";
        } else {
                # set the error code so that we can display it
                $error = $resp->error;
        }
}
echo recaptcha_get_html($publickey, $error);
?>
    <br/>
    <input type="submit" value="Голосовать" />
    </form>
<p>Внимание! После ввода кода появится ссылка для голосования</p>
<p>(Система голосования позволяет голосовать с одного компьютера один раз в сутки)</p>
  </body>
    <?php endif; ?>
  <?php endif; ?>    
</div>


Всё, готово!
Защита голосования через каптчу не панацея, но может стать препятствием для злобных накрутчиков.
p.s. дизайн и вывод каптчи можете настроить сами.

0 Thanks

Комментарии

Аватар пользователя iehon iehon 30 ноября 2011 в 12:50

cosmos: о проекте я написал в самом начале, у сайта уже как три месяца новый админ, он поставил голосовалку vote up/down по умолчанию. так что скриншот сделать не получится.

если кто сделает - приложите скриншот пожалуйста

RxB: в обычных вариантах нет каптчи. для обхода ее накрутчикам нужно использовать распозновалки, а тут уже финансовые затраты. на сколько я помню рекаптча не легко подбирается :)

Аватар пользователя Виктор Степаньков ака RxB Виктор Степаньк... 30 ноября 2011 в 12:52
"iehona" wrote:

RxB: в обычных вариантах нет каптчи. для обхода ее накрутчикам нужно использовать распозновалки, а тут уже финансовые затраты. на сколько я помню рекаптча не легко подбирается :)

Рекаптча разгадывается так же как и остальные.
Если нет капчи из коробки, это не говорит о том, что её нельзя подключить