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
привожу код моего файла целиком
// $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. дизайн и вывод каптчи можете настроить сами.
Комментарии
Возьму на заметку. В закладки.
а где можно увидеть сие
Стесняюсь спросить, чем нормальные варианты не устроили?
Виджет Fivestar это обычная форма
cosmos: о проекте я написал в самом начале, у сайта уже как три месяца новый админ, он поставил голосовалку vote up/down по умолчанию. так что скриншот сделать не получится.
если кто сделает - приложите скриншот пожалуйста
RxB: в обычных вариантах нет каптчи. для обхода ее накрутчикам нужно использовать распозновалки, а тут уже финансовые затраты. на сколько я помню рекаптча не легко подбирается
Рекаптча разгадывается так же как и остальные.
Если нет капчи из коробки, это не говорит о том, что её нельзя подключить
Большое спасибо за ваше элегантное решение. Все работает!