그누보드_아이피별 스펨 실시간 자동삭제
본문 바로가기
그누보드 _자유로운 _개발자

그누보드_아이피별 스펨 실시간 자동삭제

by AICanvas 2023. 4. 11.
728x90
SMALL
<?
$sip = array('122.254.165.221','100.100.100.5');//스팸 아이피추가 
foreach($sip as $nip) {
$sip = $nip;
$tip = $_SERVER['REMOTE_ADDR']; 
?>
<? if ($is_admin == $member[mb_nick]||$tip == $sip) { ?>
<?
$query = sql_query("select bo_table from `$g5[board_table]`");
while($row = sql_fetch_array($query)) {
  sql_query("delete from `$g5[write_prefix]$row[bo_table]` where cf_possible_ip ='$sip'");
  sql_query("delete from `$g5[write_prefix]$row[bo_table]` where cf_possible_ip ='$sip'");
    $sql = " select count(*) as cnt from ".$g5['write_prefix'].$row[bo_table]." where wr_is_comment = 0 ";
    $row = sql_fetch($sql);
    $bo_count_write = $row['cnt'];
   
    $sql = " select count(*) as cnt from ".$g5['write_prefix'].$row[bo_table]." where wr_is_comment = 1 ";
    $row = sql_fetch($sql);
    $bo_count_comment = $row['cnt'];  
  
     if (isset($_POST['proc_count'])) {
        // 원글을 얻습니다.
        //$sql = " select wr_id from {$g5['write_prefix']}{$row[bo_table]} where wr_is_comment = 0 ";
        $sql = " select a.wr_id, (count(b.wr_parent) - 1) as cnt from ".$g5['write_prefix'].$row[bo_table]." a, ".$g5['write_prefix'].$row[bo_table]." b where a.wr_id=b.wr_parent and a.wr_is_comment=0 group by a.wr_id ";
        $result = sql_query($sql);
        for ($i=0; $row=sql_fetch_array($result); $i++) {
            /*
            // 코멘트수를 얻습니다.
            $sql2 = " select count(*) as cnt from {$g5['write_prefix']}$row[bo_table] where wr_parent = '{$row['wr_id']}' and wr_is_comment = 1 ";
            $row2 = sql_fetch($sql2);
            */
            
            sql_query(" update ".$g5['write_prefix'].$row[bo_table]." set wr_comment = '".$row['cnt']."' where wr_id = '".$row['wr_id']."' ");
        }
    }
    
    // 공지사항에는 등록되어 있지만 실제 존재하지 않는 글 아이디는 삭제합니다.
    $bo_notice = "";
    $lf = "";
    if ($board['bo_notice']) {
        $tmp_array = explode(",", $board['bo_notice']);
        for ($i=0; $i<count($tmp_array); $i++) {
            $tmp_wr_id = trim($tmp_array[$i]);
            $row = sql_fetch(" select count(*) as cnt from ".$g5['write_prefix'].$row[bo_table]." where wr_id = '".$tmp_wr_id."' ");
            if ($row['cnt']) {
                $bo_notice .= $lf . $tmp_wr_id;
                $lf = ",";
            }
        }
    }
    
    $sql = " update ".$g5['board_table']."
    set bo_notice = '".$bo_notice."',
    bo_count_write = '".$bo_count_write."',
    bo_count_comment = '".$bo_count_comment."'
    where bo_table = '".$row[bo_table]."' ";  
  
  sql_query($sql);
 }
}
?>
<? }?>
728x90
LIST

댓글