連続投票の制限
投票cgiを設置したいのですがうまくいきません、集計を1日一回だったのを少し改造して即時集計にしました
一応動くのですが、連続投票できてしまいます。
連続投票を一定時間制限できるようにしたいのですがうまくいきません
60秒くらい間をおいてから投票できるようにできますか?
ip制限もあるみたいなのですがこれも機能してないです・・・
改善できるなら元のソースがかなり変わってもかまいません
連続投票制限だけでも機能できればと思っています。よろしくお願いします
local $times = time();
sub vote{
if($FORM{id}){
my $fl=0;
if(!$CK_ref){$fl=1;}
else{ if(index($ENV{'HTTP_REFERER'},index.html>=0){$fl=1;} }
if($fl){
$FORM{id}=~s/\n//g;
my $vote = $FORM{vt2}?1:0;
open(OUT,">>vote_temp.cgi"); #時間用のログファイルに書き込み
print OUT "$FORM{id}<>$ENV{'REMOTE_ADDR'}<>$FORM{vt}<>$vote<>".$times."<>\n";
close(OUT);
&reset_vote if $VT_RESET < $times;
my(@log_lines,%pt,%pt2,%cnt,$name,$value,%CKIP);
open(IN,"vote_temp.cgi");
my @log = <IN>;
close(IN);
if(@log){
my $cktime = $times - 60; #60秒制限
open(IN,"vote_ck_IP.cgi"); #投票した人のIPを記録したログ
while(<IN>){
my @ck = split('<>');
next if $_[1] < $cktime;
$CKIP{$_[0]} = $_[1];
}
close(IN);
foreach(@log){
chop;
my @rank = split('<>'); #ID<>IP<>評価<>おすすめ<>時間\n
next if $CKIP{"$rank[0]_$rank[1]"};
$pt{$rank[0].'_'.$rank[2]}++; $pt2{$rank[0]}++ if $rank[3]; $cnt{$rank[0]}++;
$CKIP{"$rank[0]_$rank[1]"} = $rank[4];
}
open(OUT,">vote_temp.cgi");
close(OUT);
open(OUT,">vote_ck_IP.cgi");
while(($name, $value) = each(%CKIP)){
print OUT "$name<>$value<>\n";
}
close(OUT);
open(IN,"log.cgi");
my @data = <IN>;
close(IN);
foreach(@data){
#集計処理長かったので省略
}
open(OUT,">vote_bf.cgi");
open(IN,"vote_log.cgi");
while(<IN>){ print OUT $_; }
close(IN);
close(OUT);
open(OUT,">vote_log.cgi");
print OUT @log_lines;
print OUT "\n1;\n";
close(OUT);
}
&make_vote_ck('set');
}
}
sub reset_vote{
my @log;
foreach my $i(1..$LAST_ID){
next if !@{$VT[$i]};
$VT[$i][18] = $VT[$i][7];
$VT[$i][19] = $VT[$i][8];
$VT[$i][20] = $VT[$i][0];
foreach my $j(0..8){ $VT[$i][$j] = 0; }
push(@log,'$VT['.$i.'] = ['.(join(',',@{$VT[$i]}))."];\n");
}
open(OUT,">vote_log.cgi");
print OUT @log;
print OUT "\n1;\n";
close(OUT);
&make_vote_ck('reset');
}
sub make_vote_ck{
if($_[0] eq 'set'){
my @t =localtime($times + 86400);
$VT_TIME = timelocal(0,0,5,$t[3],$t[4],$t[5]);
$VT_RANK = $VT_RUI = $VT_RECO = $VT_RCRUI = $VT_COUNT = $VT_CTRUI = $VRK_CK = 1;
}
if($_[0] eq 'reset'){
my @m =localtime($times);
$m[4] += 1;
if($m[4] > 12){ $m[4] = 1; $m[5] += 1; }
$VT_RESET = timelocal(0,0,2,1,$m[4],$m[5]);
$VT_RANK = $VT_RECO = $VRK_RS = $VRK_CK = 1;
}
if($_[0] eq 'restore'){ $VT_RANK = $VT_RUI = $VT_RCRUI = $VT_RECO = $VT_COUNT = $VT_CTRUI = $VRK_CK = 1; }
open(OUT,">vote_ck.cgi");
print OUT "\$VT_TIME = '".$VT_TIME. "';\n";
print OUT "\$VT_RESET = '".$VT_RESET. "';\n";
print OUT "\$VT_RANK = '".$VT_RANK. "';\n";
print OUT "\$VT_RUI = '".$VT_RUI. "';\n";
print OUT "\$VT_RECO = '".$VT_RECO. "';\n";
print OUT "\$VT_RCRUI = '".$VT_RCRUI. "';\n";
print OUT "\$VT_COUNT = '".$VT_COUNT. "';\n";
print OUT "\$VT_CTRUI = '".$VT_CTRUI. "';\n";
print OUT "\$VRK_CK = '".$VRK_CK. "';\n";
print OUT "\$VRK_RS = '".$VRK_RS. "';\n";
print OUT "\$LAST_ID = '".$LAST_ID. "';\n";
print OUT "\n1;\n";
close(OUT);
}
補足
色々書くところ足りなくてすいません。 とりあえず大体書き出してみます。長くてすいません。 # ログ書込処理 # sub regist { local($job) = @_; # 日時の取得 $ENV{'TZ'} = "JST-9"; $times = time; ($sec,$min,$hour,$mday,$mon,$year) = localtime($times); $date = sprintf("%1d/%1d %2d:%2d",$mon+1,$mday,$hour,$min,$sec); # ログ形態を判断 if ($job eq 'into') { $in{'comment'} = "$in_msg"; $name = $in{'name'}; $ncolor = $in{'ncolor'}; $scolor = $in{'scolor'}; } elsif ($job eq 'bye') { $in{'comment'} = "$out_msg"; $name = $in{'name'}; $ncolor = $in{'ncolor'}; $scolor = $in{'scolor'}; $size = $in{'size'}; } else { $name = $in{'name'}; $ncolor = $in{'ncolor'}; $scolor = $in{'scolor'}; $size = $in{'size'}; $logs = $in{'logs'}; } open(IN,"$logfile") || &error("Open Error : $logfile"); @lines = <IN>; close(IN); $i=0; $match=0; @temp=(); foreach (@lines) { chop($_); if ($match) { $i++; push(@temp,"$_\n"); } elsif ($_ eq '<!--START-->') { $match=1; } if ($i > $logs-2 || $_ eq '<!--END-->') { last; } } # ログ更新処理 &renew_log; $logs=@line # 参加者機能 &sanka; # 内容表示 if (!$job) { &header; print "<META HTTP-EQUIV=\"refresh\" CONTENT=\"$rtime; URL=$chat_log\"></head>\n$body\n"; print "参加者-$member:$num$sikiri\n"; print "<font color=\"$ncolor\">$name</font> > <font color=\"$scolor\" size=\"$size\">$in{'comment'}</font> ($date)$sikiri\n"; print @temp; print "</body>\n</html>\n"; exit; } } #----------------# # ログ更新処理 # #----------------# sub renew_log { open(OUT,">$logfile") || &error("Write Error : $logfile"); print OUT "<html><head>\n"; print OUT "<META HTTP-EQUIV=\"Pragma\" CONTENT=\"no-cache\">\n"; print OUT "<META HTTP-EQUIV=\"Content-Type\" CONTENT=\"text/html; charset=Shift_JIS\">\n"; print OUT "<META HTTP-EQUIV=\"refresh\" CONTENT=\"$rtime; URL=$chat_log\"></head>\n$body\n"; # 参加者表示 print OUT "参加者-$member:$num$sikiri\n<!--START-->\n"; print OUT "<font color=\"$ncolor\">$name</font> > <font color=\"$scolor\" size=\"$size\">$in{'comment'}</font> ($date)$sikiri\n"; print OUT @temp; close(IN); } 「$logs=@line」も入れてみたのですが やはり書き込み時にログがクリアされてしまいます。 どこを変えたらいいのでしょうか、 よろしくお願いします。