한번 읽은글은 동일ID에서는 카운트를 증가시키지 않음 > 그누보드5 팁자료실

그누보드5 팁자료실

한번 읽은글은 동일ID에서는 카운트를 증가시키지 않음 정보

한번 읽은글은 동일ID에서는 카운트를 증가시키지 않음

본문

일반적으로 조회수 늘리기 팁이나 문의는 많지만, 조회수 늘지 않기를 원하는 경우는 없죠.
아래 팁은 조회수 늘리지 않기 위한 팁입니다.

아이디당 게시글을 오직 한번만 조회수를 늘립니다.
팁 내용중 오류나 이상한것이 있으면 알려주세요. 일단 필요해서 만들기는 했는데, 더 쉬운 방법이 있을지 궁금하네요.

그누보드는 세션을 이용해서 조회수 증가를 막지만, 브라우저를 종료하면 다시 조회수가 올라간다는 점에서 제가 원하는 기능에 부족하더라구요.

쪽지로 힌트를 주신 강한남v님 감사합니다.

1. 읽은것을 기록할 테이블 생성
CREATE TABLE IF NOT EXISTS `g5_board_hit` (
  `bh_idx` int(11) NOT NULL auto_increment,
  `bo_table` varchar(50) NOT NULL,
  `wr_id` int(11) NOT NULL,
  `mb_id` varchar(50) NOT NULL,
  `bh_datetime` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  PRIMARY KEY (`bh_id`),
  KEY `mb_id` (`mb_id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8;


2. 그누보드5 / bbs / board.php  116~120줄

    // 한번 읽은글은 브라우저를 닫기전까지는 카운트를 증가시키지 않음
    $ss_name = 'ss_view_'.$bo_table.'_'.$wr_id;
    if (!get_session($ss_name))
    {
        sql_query(" update {$write_table} set wr_hit = wr_hit + 1 where wr_id = '{$wr_id}' ");

를 아래와 같이 변경합니다.

    // 한번 읽은글은 브라우저를 닫기전까지는 카운트를 증가시키지 않음
    $ss_name = "ss_view_{$bo_table}_{$wr_id}";
    if (!get_session($ss_name))
    {
        if ($bo_table == "게시판이름") { // 읽기를 제어할 게시판 이름 / 읽기권한은 회원전용으로
            $sql = " select count(*) as cnt from g5_board_hit where bo_table = '". $bo_table ."' and wr_id = '". $wr_id ."' and mb_id = '". $member['mb_id'] ."' ";
            $row = sql_fetch($sql);
            if (!$row[cnt]) { // 처음 읽을때
                sql_query(" insert into g5_board_hit (bo_table, wr_id, mb_id, bh_datetime) values ('". $bo_table ."', '". $wr_id ."', '". $member['mb_id'] ."', '". date("Y-m-d H:i:s") ."')");
                sql_query(" update $write_table set wr_hit = wr_hit + 1 where wr_id = '$wr_id' ");
            } else { // 읽은기록이 있을때
            }
        } else {
            sql_query(" update $write_table set wr_hit = wr_hit + 1 where wr_id = '$wr_id' ");
        }
추천
3

댓글 3개

전체 2,431 |RSS
그누보드5 팁자료실 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT