그누보드 [G4] 한번 읽은글은 동일ID에서는 카운트를 증가시키지 않음
페이지 정보
본문
일반적으로 조회수 늘리기 팁이나 문의는 많지만, 조회수 늘지 않기를 원하는 경우는 없죠.
아래 팁은 조회수 늘리지 않기 위한 팁입니다.
아이디당 게시글을 오직 한번만 조회수를 늘립니다.
팁 내용중 오류나 이상한것이 있으면 알려주세요. 일단 필요해서 만들기는 했는데, 더 쉬운 방법이 있을지 궁굼하네요.
그누보드는 세션을 이용해서 조회수 증가를 막지만, 브라우저를 종료하면 다시 조회수가 올라간다는 점에서 제가 원하는 기능에 부족하더라구요.
1. 읽은것을 기록할 테이블 생성
CREATE TABLE IF NOT EXISTS `g4_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. 그누보드4 / bbs / board.php 119~123줄
// 한번 읽은글은 브라우저를 닫기전까지는 카운트를 증가시키지 않음
$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 g4_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 g4_board_hit (bo_table, wr_id, mb_id, wr_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' ");
}
아래 팁은 조회수 늘리지 않기 위한 팁입니다.
아이디당 게시글을 오직 한번만 조회수를 늘립니다.
팁 내용중 오류나 이상한것이 있으면 알려주세요. 일단 필요해서 만들기는 했는데, 더 쉬운 방법이 있을지 궁굼하네요.
그누보드는 세션을 이용해서 조회수 증가를 막지만, 브라우저를 종료하면 다시 조회수가 올라간다는 점에서 제가 원하는 기능에 부족하더라구요.
1. 읽은것을 기록할 테이블 생성
CREATE TABLE IF NOT EXISTS `g4_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. 그누보드4 / bbs / board.php 119~123줄
// 한번 읽은글은 브라우저를 닫기전까지는 카운트를 증가시키지 않음
$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 g4_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 g4_board_hit (bo_table, wr_id, mb_id, wr_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' ");
}
댓글목록
등록된 댓글이 없습니다.