<?
//홈페이지 상단에 아래 부분만 붙이면 됩니다.
========== 시작 ============
include '/Visit.php';
session_start();
$visit = new Visit($dbconn);
$visit->listenVisit();
$visit_total = $visit->getVisit(); //전체 방문자
$visit_today = $visit->getVisit(date('Y'),date('n'),date('j')); //오늘방문자
unset($visit);
========== 끝 ============
아래는 클래스 파일입니다.
========================
- class.Visit.php
========================
/* 방문자 기록 관리 클래스 */
Class Visit
{
var $dbconn;
var $sql;
var $error_msg;
function Visit($dbconn){
$this->dbconn = $dbconn;
}
/*방문자 추출 메소드 */
function getVisit($syear='', $smonth='', $sday=''){
if($syear == '' && $smonth == '' && $sday == ''){
$this->sql = "select sum(hit) as hit from visit "; //총방문자 수
}
else {
$this->sql = "select hit from visit ";
if($syear != "")
$this->sql .= "where syear='$syear' ";
if($smonth != "")
$this->sql .= "and smonth='$smonth' ";
if($sday != "")
$this->sql .= "and sday='$sday' ";
}
$result = mysql_query($this->sql, $this->dbconn);
if($result){
if(mysql_num_rows($result))
return mysql_result($result,0,'hit');
else
return 0;
}
else {
$this->error_msg = mysql_error();
return 0;
}
}
function addVisit($syear, $smonth, $sday){
$this->sql = "insert into visit(syear, smonth, sday, hit)
values('$syear', '$smonth', '$sday', 1)";
$result = mysql_query($this->sql, $this->dbconn);
if($result)
return true;
else {
$this->error_msg = mysql_error();
return false;
}
}
function upVisit(){
$syear = date('Y');
$smonth = date('n');
$sday = date('j');
$is_data = $this->isVisit($syear, $smonth, $sday);
if($is_data)
$this->editVisit($syear, $smonth, $sday);
else
$this->addVisit($syear, $smonth, $sday);
}
function editVisit($syear, $smonth, $sday){
$this->sql = "update visit set hit=hit+1
where syear='$syear' and smonth='$smonth' and sday='$sday'";
$result = mysql_query($this->sql, $this->dbconn);
if($result)
return true;
else {
$this->error_msg = mysql_error();
return false;
}
}
function delVisit($uid){
$this->sql = "delete from visit where uid=$uid";
$result = mysql_query($this->sql, $this->dbconn);
if($result)
return true;
else {
$this->error_msg = mysql_error();
return false;
}
}
function isVisit($syear, $smonth, $sday){
$this->sql = "select uid from visit
where syear='$syear' and smonth='$smonth' and sday='$sday'";
$result = mysql_query($this->sql, $this->dbconn);
if($result){
if(mysql_num_rows($result))
return 1;
else
return 0;
}
else {
$this->error_msg = mysql_error();
return 1;
}
}
function listVisit($pageInfo, $syear='', $smonth='', $sday=''){
$this->sql = "select syear, smonth, sday, hit
from visit ";
if($syear != '') $this->sql .= " where syear='$syear'";
if($smonth != '') $this->sql .= " and smonth='$smonth'";
if($sday != '') $this->sql .= " and sday='$sday'";
$this->sql .= " order by syear desc, smonth desc, sday desc";
$result = mysql_query($this->sql, $this->dbconn);
if($result){
$j=0;
for($i=$pageInfo["first"]; $i<=$pageInfo["last"]; $i++){
$info["num"][$j] = $pageInfo["cnt"] - $i;
$info["syear"][$j] = mysql_result($result,$i,"syear");
$info["smonth"][$j] = mysql_result($result,$i,"smonth");
$info["sday"][$j] = mysql_result($result,$i,"sday");
$info["hit"][$j] = mysql_result($result,$i,"hit");
$j++;
}
return $info;
}
else {
$this->error_msg = mysql_error();
return false;
}
}
/* 20분 기준 방문자 체크 메소드 */
function listenVisit(){
$now_visit_date = mktime(date('H'),date('i'),0,date('m'),date('d'),date('Y'));
if($_COOKIE['visit_date'] != ''){
$old_visit_date = $_COOKIE['visit_date'];
$is_first = false;
}
else {
$old_visit_date = $now_visit_date;
setcookie('visit_date', $now_visit_date);
$is_first = true;
}
$diff_date = $now_visit_date - $old_visit_date;
if($diff_date > 1200 || $is_first == true){ //20분 응답 60 * 20
setcookie('visit_date', $now_visit_date);
$this->upVisit();
}
}
function getCnt($syear='', $smonth='', $sday=''){
$this->sql = "select count(uid) as cnt from visit";
if($syear != '') $this->sql .= " where syear='$syear'";
if($smonth != '') $this->sql .= " and smonth='$smonth'";
if($sday != '') $this->sql .= " and sday='$sday'";
$result = mysql_query($this->sql, $this->dbconn);
if($result){
$cnt = mysql_result($result,0,"cnt");
return $cnt;
}
else {
$this->error_msg = mysql_error();
return 0;
}
}
/* error를 출력하는 메소드 */
/* filter 0-error발생시 출력, 1-무조건 출력 */
function printErr($filter=0){
if($this->error_msg != '' || $filter == 1){
echo '<br>'.$this->sql;
echo '<br>'.$this->error_msg;
}
}
}
아래 테이블을 만든 후 사용해 주세요 ^^;
create table visit (
uid int, auto_increment,
syear int,
smonth int,
sday int,
hit int
}
?><div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
//홈페이지 상단에 아래 부분만 붙이면 됩니다.
========== 시작 ============
include '/Visit.php';
session_start();
$visit = new Visit($dbconn);
$visit->listenVisit();
$visit_total = $visit->getVisit(); //전체 방문자
$visit_today = $visit->getVisit(date('Y'),date('n'),date('j')); //오늘방문자
unset($visit);
========== 끝 ============
아래는 클래스 파일입니다.
========================
- class.Visit.php
========================
/* 방문자 기록 관리 클래스 */
Class Visit
{
var $dbconn;
var $sql;
var $error_msg;
function Visit($dbconn){
$this->dbconn = $dbconn;
}
/*방문자 추출 메소드 */
function getVisit($syear='', $smonth='', $sday=''){
if($syear == '' && $smonth == '' && $sday == ''){
$this->sql = "select sum(hit) as hit from visit "; //총방문자 수
}
else {
$this->sql = "select hit from visit ";
if($syear != "")
$this->sql .= "where syear='$syear' ";
if($smonth != "")
$this->sql .= "and smonth='$smonth' ";
if($sday != "")
$this->sql .= "and sday='$sday' ";
}
$result = mysql_query($this->sql, $this->dbconn);
if($result){
if(mysql_num_rows($result))
return mysql_result($result,0,'hit');
else
return 0;
}
else {
$this->error_msg = mysql_error();
return 0;
}
}
function addVisit($syear, $smonth, $sday){
$this->sql = "insert into visit(syear, smonth, sday, hit)
values('$syear', '$smonth', '$sday', 1)";
$result = mysql_query($this->sql, $this->dbconn);
if($result)
return true;
else {
$this->error_msg = mysql_error();
return false;
}
}
function upVisit(){
$syear = date('Y');
$smonth = date('n');
$sday = date('j');
$is_data = $this->isVisit($syear, $smonth, $sday);
if($is_data)
$this->editVisit($syear, $smonth, $sday);
else
$this->addVisit($syear, $smonth, $sday);
}
function editVisit($syear, $smonth, $sday){
$this->sql = "update visit set hit=hit+1
where syear='$syear' and smonth='$smonth' and sday='$sday'";
$result = mysql_query($this->sql, $this->dbconn);
if($result)
return true;
else {
$this->error_msg = mysql_error();
return false;
}
}
function delVisit($uid){
$this->sql = "delete from visit where uid=$uid";
$result = mysql_query($this->sql, $this->dbconn);
if($result)
return true;
else {
$this->error_msg = mysql_error();
return false;
}
}
function isVisit($syear, $smonth, $sday){
$this->sql = "select uid from visit
where syear='$syear' and smonth='$smonth' and sday='$sday'";
$result = mysql_query($this->sql, $this->dbconn);
if($result){
if(mysql_num_rows($result))
return 1;
else
return 0;
}
else {
$this->error_msg = mysql_error();
return 1;
}
}
function listVisit($pageInfo, $syear='', $smonth='', $sday=''){
$this->sql = "select syear, smonth, sday, hit
from visit ";
if($syear != '') $this->sql .= " where syear='$syear'";
if($smonth != '') $this->sql .= " and smonth='$smonth'";
if($sday != '') $this->sql .= " and sday='$sday'";
$this->sql .= " order by syear desc, smonth desc, sday desc";
$result = mysql_query($this->sql, $this->dbconn);
if($result){
$j=0;
for($i=$pageInfo["first"]; $i<=$pageInfo["last"]; $i++){
$info["num"][$j] = $pageInfo["cnt"] - $i;
$info["syear"][$j] = mysql_result($result,$i,"syear");
$info["smonth"][$j] = mysql_result($result,$i,"smonth");
$info["sday"][$j] = mysql_result($result,$i,"sday");
$info["hit"][$j] = mysql_result($result,$i,"hit");
$j++;
}
return $info;
}
else {
$this->error_msg = mysql_error();
return false;
}
}
/* 20분 기준 방문자 체크 메소드 */
function listenVisit(){
$now_visit_date = mktime(date('H'),date('i'),0,date('m'),date('d'),date('Y'));
if($_COOKIE['visit_date'] != ''){
$old_visit_date = $_COOKIE['visit_date'];
$is_first = false;
}
else {
$old_visit_date = $now_visit_date;
setcookie('visit_date', $now_visit_date);
$is_first = true;
}
$diff_date = $now_visit_date - $old_visit_date;
if($diff_date > 1200 || $is_first == true){ //20분 응답 60 * 20
setcookie('visit_date', $now_visit_date);
$this->upVisit();
}
}
function getCnt($syear='', $smonth='', $sday=''){
$this->sql = "select count(uid) as cnt from visit";
if($syear != '') $this->sql .= " where syear='$syear'";
if($smonth != '') $this->sql .= " and smonth='$smonth'";
if($sday != '') $this->sql .= " and sday='$sday'";
$result = mysql_query($this->sql, $this->dbconn);
if($result){
$cnt = mysql_result($result,0,"cnt");
return $cnt;
}
else {
$this->error_msg = mysql_error();
return 0;
}
}
/* error를 출력하는 메소드 */
/* filter 0-error발생시 출력, 1-무조건 출력 */
function printErr($filter=0){
if($this->error_msg != '' || $filter == 1){
echo '<br>'.$this->sql;
echo '<br>'.$this->error_msg;
}
}
}
아래 테이블을 만든 후 사용해 주세요 ^^;
create table visit (
uid int, auto_increment,
syear int,
smonth int,
sday int,
hit int
}
?><div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 1130 | 18년 전 | 2464 | ||
| 1129 | 18년 전 | 2448 | ||
| 1128 | 18년 전 | 2320 | ||
| 1127 | 18년 전 | 2557 | ||
| 1126 |
|
18년 전 | 3848 | |
| 1125 | 18년 전 | 3653 | ||
| 1124 |
|
18년 전 | 2086 | |
| 1123 | 18년 전 | 2021 | ||
| 1122 | 18년 전 | 1563 | ||
| 1121 | 18년 전 | 3891 | ||
| 1120 | 18년 전 | 5892 | ||
| 1119 | 18년 전 | 6981 | ||
| 1118 | 18년 전 | 2466 | ||
| 1117 |
BEST79
|
18년 전 | 2715 | |
| 1116 | 18년 전 | 4175 | ||
| 1115 | 18년 전 | 2176 | ||
| 1114 |
|
18년 전 | 3628 | |
| 1113 | 18년 전 | 2871 | ||
| 1112 | 18년 전 | 2727 | ||
| 1111 | 18년 전 | 2193 | ||
| 1110 | 18년 전 | 2464 | ||
| 1109 | 18년 전 | 2601 | ||
| 1108 | 18년 전 | 3083 | ||
| 1107 | 18년 전 | 3732 | ||
| 1106 | 18년 전 | 3268 | ||
| 1105 | 18년 전 | 2779 | ||
| 1104 |
|
18년 전 | 2269 | |
| 1103 | 18년 전 | 2933 | ||
| 1102 | 18년 전 | 3023 | ||
| 1101 | 18년 전 | 2536 | ||
| 1100 | 18년 전 | 2297 | ||
| 1099 | 18년 전 | 3324 | ||
| 1098 | 18년 전 | 4844 | ||
| 1097 | 18년 전 | 5075 | ||
| 1096 | 18년 전 | 2295 | ||
| 1095 | 18년 전 | 2184 | ||
| 1094 | 18년 전 | 4998 | ||
| 1093 | 18년 전 | 8958 | ||
| 1092 | 18년 전 | 2039 | ||
| 1091 |
DeepnBlue
|
18년 전 | 4918 | |
| 1090 |
|
18년 전 | 4364 | |
| 1089 |
도날드주주
|
18년 전 | 2603 | |
| 1088 |
|
18년 전 | 4957 | |
| 1087 | 18년 전 | 2784 | ||
| 1086 | 18년 전 | 3669 | ||
| 1085 | 18년 전 | 2616 | ||
| 1084 | 18년 전 | 3431 | ||
| 1083 | 18년 전 | 1940 | ||
| 1082 | 18년 전 | 5373 | ||
| 1081 | 18년 전 | 1689 | ||
| 1080 | 18년 전 | 6049 | ||
| 1079 |
|
18년 전 | 2871 | |
| 1078 | 18년 전 | 6036 | ||
| 1077 |
|
18년 전 | 6834 | |
| 1076 | 18년 전 | 3725 | ||
| 1075 | 18년 전 | 2204 | ||
| 1074 |
hwatta
|
18년 전 | 2095 | |
| 1073 | 18년 전 | 6899 | ||
| 1072 | 18년 전 | 2397 | ||
| 1071 | 18년 전 | 3952 | ||
| 1070 |
|
18년 전 | 5341 | |
| 1069 | 18년 전 | 2689 | ||
| 1068 | 18년 전 | 1744 | ||
| 1067 | 18년 전 | 1576 | ||
| 1066 | 18년 전 | 1523 | ||
| 1065 | 18년 전 | 1799 | ||
| 1064 | 18년 전 | 1797 | ||
| 1063 | 18년 전 | 1780 | ||
| 1062 | 18년 전 | 1715 | ||
| 1061 | 18년 전 | 2506 | ||
| 1060 | 18년 전 | 2308 | ||
| 1059 | 18년 전 | 3464 | ||
| 1058 | 18년 전 | 2588 | ||
| 1057 | 18년 전 | 2573 | ||
| 1056 | 18년 전 | 3409 | ||
| 1055 | 18년 전 | 4622 | ||
| 1054 | 18년 전 | 2961 | ||
| 1053 | 18년 전 | 2798 | ||
| 1052 | 18년 전 | 3346 | ||
| 1051 | 18년 전 | 6278 | ||
| 1050 | 18년 전 | 2180 | ||
| 1049 | 18년 전 | 1990 | ||
| 1048 | 18년 전 | 1943 | ||
| 1047 | 18년 전 | 2008 | ||
| 1046 | 18년 전 | 3192 | ||
| 1045 | 18년 전 | 2263 | ||
| 1044 | 18년 전 | 1954 | ||
| 1043 | 18년 전 | 1618 | ||
| 1042 | 18년 전 | 2077 | ||
| 1041 | 18년 전 | 3362 | ||
| 1040 | 18년 전 | 3232 | ||
| 1039 | 18년 전 | 1918 | ||
| 1038 | 18년 전 | 1494 | ||
| 1037 | 18년 전 | 3183 | ||
| 1036 | 18년 전 | 2056 | ||
| 1035 | 18년 전 | 1613 | ||
| 1034 | 18년 전 | 2837 | ||
| 1033 | 18년 전 | 1970 | ||
| 1032 | 18년 전 | 1841 | ||
| 1031 | 18년 전 | 1811 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기