Можно ли сделать так, чтобы с одного IP возможно было проголосовать только один раз?
Quote from: BLACKSnake on October 29, 2010, 11:21:49 AM
Можно ли сделать так, чтобы с одного IP возможно было проголосовать только один раз?
Открыть:./ratepic.phpНайти:$sql = "SELECT null FROM {$CONFIG['TABLE_VOTES']} WHERE pic_id = $pic AND user_md5_id = '$user_md5_id'";
После добавить:$sql2 = "SELECT null FROM {$CONFIG['TABLE_VOTE_STATS']} WHERE pid = $pic AND ip = '$raw_ip'";
Найти:$result = cpg_db_query($sql);
После добавить:$result2 = cpg_db_query($sql2);
Найти:if (mysql_num_rows($result)) {
Заменить на:if (mysql_num_rows($result) OR mysql_num_rows($result2)) {
Найти:mysql_free_result($result);
После добавить:mysql_free_result($result2);
Открыть:./include/themes.inc.phpНайти: (обратите внимание на пустую строку перед искомым кодом)
if (!(USER_CAN_RATE_PICTURES && $CURRENT_ALBUM_DATA['votes'] == 'YES')) {
ПЕРЕД добавить:global $raw_ip;
Найти:$result = cpg_db_query("SELECT pic_id FROM {$CONFIG['TABLE_VOTES']} WHERE pic_id={$CURRENT_PIC_DATA['pid']} AND user_md5_id='$user_md5_id'");
После добавить:$result2 = cpg_db_query("SELECT pid FROM {$CONFIG['TABLE_VOTE_STATS']} WHERE pid={$CURRENT_PIC_DATA['pid']} AND ip='$raw_ip'");
Найти:} elseif (!mysql_num_rows($result)) {
Заменить на:} elseif (!mysql_num_rows($result) AND !mysql_num_rows($result2)) {
Всё.
Сделал по инструкции.
Все равно позволяет голосовать после удаления куков.
Только счетчик голосов не изменяется, а общий бал меняется.
Quote from: BLACKSnake on November 08, 2010, 09:54:36 AM
Сделал по инструкции.
Все равно позволяет голосовать после удаления куков.
Только счетчик голосов не изменяется, а общий бал меняется.
Выложите в архиве измененные Вами файлы:
- ./ratepic.php
- ./include/themes.inc.php