我制作了一个代码,用于生成投票系统和您的网站。他的外表如下所示:
我制作了以下代码:JavaScipt:
jQuery(document).ready(function() {
jQuery("a#up").click(function() {
jQuery('.rating').html('');
jQuery('#loading').show();
post_id = jQuery(this).data("post_id");
jQuery.ajax({
type: "post",
url: ajax_var.url,
data: "action=post_id&nonce=" + ajax_var.nonce + "&post_rating=up&post_id=" + post_id,
success: function(data) {
jQuery('#loading').hide();
jQuery('.rating').html(data);
}
});
return false;
});
jQuery("a#down").click(function() {
post_id = jQuery(this).data("post_id");
jQuery.ajax({
type: "post",
url: ajax_var.url,
data: "action=post_id&nonce=" + ajax_var.nonce + "&post_rating=down&post_id=" + post_id,
success: function(data) {
jQuery('.rating').html(data);
}
});
return false;
});
});
以下PHP代码在我的functions.php
中 <?php
function add_rating_script() {
wp_enqueue_script('rating', get_stylesheet_directory_uri() . '/js/rating.js', array('jquery'), '', true);
wp_localize_script('rating', 'ajax_var', array('url' => admin_url('admin-ajax.php'), 'nonce' => wp_create_nonce('ajax-nonce')));
}
function update_rating() {
// Check for nonce security
$nonce = $_POST['nonce'];
if (!wp_verify_nonce($nonce, 'ajax-nonce'))
die('Busted!');
if (isset($_POST['post_rating'])) {
// Retrieve user IP address
$ip = $_SERVER['REMOTE_ADDR'];
$post_id = $_POST['post_id'];
// Get voters'IPs for the current post
$meta_IP = get_post_meta($post_id, "voted_IP");
$voted_IP = $meta_IP[0];
if (!is_array($voted_IP))
$voted_IP = array();
// Get votes count for the current post
$meta_count_up = get_post_meta($post_id, "votes_up", true);
$meta_count_down = get_post_meta($post_id, "votes_down", true);
// Use has already voted ?
if (!hasAlreadyVoted($post_id)) {
$voted_IP[$ip] = time();
if ($_POST['post_rating'] == 'up') {
// Save IP and increase votes count
update_post_meta($post_id, "voted_IP", $voted_IP);
update_post_meta($post_id, "votes_up", ++$meta_count_up);
echo '<p class=\'message\'>Esse artigo já ajudou <span class=\'count\'>' . $meta_count_up . '</span> pessoas </p>';
}elseif($_POST['post_rating'] == 'down'){
update_post_meta($post_id, "voted_IP", $voted_IP);
update_post_meta($post_id, "votes_down", ++$meta_count_down);
echo '<p class=\'message\'>Obrigado pelo seu voto.</p>';
}
}
else
echo '<p class=\'message\'>Você já enviou o seu voto.</p>';
}
exit;
}
function hasAlreadyVoted($post_id) {
$timebeforerevote = 120;
$meta_IP = get_post_meta($post_id, "voted_IP");
$voted_IP = $meta_IP[0];
if (!is_array($voted_IP))
$voted_IP = array();
$ip = $_SERVER['REMOTE_ADDR'];
if (in_array($ip, array_keys($voted_IP))) {
$time = $voted_IP[$ip];
$now = time();
if (round(($now - $time) / 60) > $timebeforerevote)
return false;
return true;
}
return false;
}
wp_localize_script('rating', 'ajax_var', array(
'url' => admin_url('admin-ajax.php'),
'nonce' => wp_create_nonce('ajax-nonce')
));
add_action('wp_enqueue_scripts', 'add_rating_script');
add_action('wp_ajax_post_id', 'update_rating');
add_action('wp_ajax_nopriv_post_id', 'update_rating');
问题是要防止用户在同一篇文章中多次投票我保存了IP并进行了比较,但我相信随着时间的推移会让WordPress表充电并超级慢。有没有人知道我优化这段代码的事情?
答案 0 :(得分:0)
优化的一个技巧可能是在投票后设置一个cookie并将其作为第一道防线。这将在大量用例中停止相当多的数据库回调。如果未设置cookie,则只检查您的表中的IP地址,以确定他们是否已经投票。
由于用户可以切换浏览器,清除cookie等,因此仅使用cookie的方法显然不起作用 - 并且对于那些用户,您将像现在一样查找其IP(尽管仍有可能绕过方法)如果他们正在共享互联网连接/ IP地址 - 即使用相同的星巴克Wifi连接进行投票,那么您可能会阻止合法用户投票。
至少通过首先检查cookie,您可以主动防止大量可能不必要的数据库事务。