강의 컨설팅 트레이닝 무료진단 무료책자 마케팅편지 마케팅정보공유 다이어리 서비스제휴 고객센터

현재접속자 구하기
작성자 : 13 김영철
등록날짜 : 2009.01.14 22:23
2,795

출처: Unix.co.kr

 

웹브라우저로 현재 접속자수를 볼 수 있습니다. ^^

 

안녕하세요. 하늘입니다.
제가 전번에 짜근 커뮤니케이션의 게시판에서 받은 질문을 보고 재미있어서 제작한 것입니다.
보통 웹서버의 특성상 - 결과를 보내고 끊어버리는 -

현재 접속중인 정확한 인원을 나타내기는 힘들죠.
여러가지 방법이 있겠지만 전 리프레쉬 기능을 이용해서 클라이언트와 반복적으로 접속하는 방법으로 만들어 보았습니다.
사용할 때는 작은 프레임을 만들어서 그 안에 두고 사용하시는 것이 좋을 겁니다.
정기적으로 리므레쉬를 하니까요.
이것이 싫으신 분들은 쿠키를 이용하면 되는데, 이 방법이 더 정확할것 같아서요.

아래 소스입니다.

================================================================
테이블 스키마
================================================================
# MySQL dump 6.4
#
#--------------------------------------------------------
# Server version 3.22.27

#
# Table structure for table 'session'
#
CREATE TABLE session (
ip varchar(15) DEFAULT '' NOT NULL,
last_time timestamp(14),
PRIMARY KEY (ip)
);

#
# Dumping data for table 'session'
#
============================================

==============================================
session.php3
===============================================
<?

// Mysql DB 사용자 정보
$db_host = "host_name";
$db_user = "user_name";
$db_passwd = "passwd";
$db_name = "db_name";

// 사용자의 정보를 갱신하는 시간 간격이다.
// 홈페이지 동시 접속수의 평균을 내서 가장 적절한 값을 찾는다.
// 보통 10초에서 30초 사이의 값이면 좋다고 생각한다.
$refresh_time = 30;

// 접속이 끊긴 사용자의 한계시간.
// 보통 리프레시 타임보다 5~10초 정도 많게 설정하면 된다.
$kill_time = 40;

// 데이타 베이스 연결
$connect = mysql_connect( $db_host , $db_user , $db_passwd ) or die ( "DB Server Error" );
mysql_select_db( $db_name ) or die( "DB Error" );

// 접속이 끊긴 사용자 삭제
$query = "DELETE FROM session WHERE (now() - last_time) > $kill_time";
mysql_query( $query , $connect );

// 현접속 사용자 확인
$query = "SELECT * FROM session WHERE ip = '$REMOTE_ADDR'";
$result = mysql_query( $query , $connect );
$total = mysql_affected_rows();

// 이미 접속한 사용자라면...
if($total > 0)
{
// 마지막 접속 시간 갱신
$query = "UPDATE session SET last_time = now() WHERE ip = '$REMOTE_ADDR'";
mysql_query( $query, $connect );
}
//처음 접속한 사용자
else
{
$query = "INSERT INTO session VALUES('$REMOTE_ADDR',now())";
mysql_query( $query, $connect );
}

// 총 접속자수 계산
$query = "SELECT count(*) FROM session";
$result = mysql_query( $query , $connect );
$row = mysql_fetch_array( $result );

mysql_close($connect);

// 리프레쉬 해더
echo " <html><head> ";
echo " <meta http-equiv='refresh' content='$refresh_time;url=$PHP_SELF'> ";
echo " </head> ";

echo " <body bgcolor=#CCCC99 text='blue'> ";
echo " <center><font size=1>Now $row[0] Contact</font></center> ";
echo " </body></html> ";
=====================================================================

출처 : Tong - 드렁크수달스님의 ■ PHP ■통

"쇼핑몰·홈페이지·오픈마켓
블로그·페이스북·이메일 등의 각종 마케팅 글쓰기,
각종 광고, 영업, 판매, 제안서, 전단지
반응율 3배×10배 이상 높이는 마법의 8단계 공식"
자세히보기

Comments

번호 제목 글쓴이 날짜 조회
3285 이것은 AI파일 미리보기입니다. 댓글3 M 최고의하루 01.15 3587
3284 이미지미리보기pds파일미리보기파일입니다^^ 댓글2 99 단국강토 01.14 2825
3283 동영상 캡쳐(Capture) 아주 쉽게 하기~ 99 단국강토 01.14 2615
3282 자판기안의 특수문자 99 단국강토 01.13 2530
3281 ntdll.dll 오류 해결방법 M 최고관리자 01.12 4392
3280 인터넷 동영상 저장하기 - 넷트랜스포터 사용 - M 최고의하루 01.12 3097
3279 옛날 기사를 찾아보고 싶을때 99 단국강토 01.08 2230
3278 CD 음악 mp3로 바꾸기 99 단국강토 01.08 2498
3277 알씨로 초간단 동영상 슬라이드쇼 만들기 99 단국강토 01.07 2841
3276 IP 추적은 어떻게 하는가? 99 단국강토 01.07 2391
3275 일본어로 된 웹을 한글로 즐기기 99 단국강토 01.06 2351
3274 이것은 AI파일 미리보기입니다. 댓글2 M 최고의하루 01.15 4029
3273 이미지미리보기pds파일미리보기파일입니다^^ 99 단국강토 01.14 2446
3272 동영상 캡쳐(Capture) 아주 쉽게 하기~ 99 단국강토 01.14 2782
3271 공유기 차단 무력화 시키는 법 99 단국강토 01.13 3540
3270 자판기안의 특수문자 99 단국강토 01.13 2363
3269 ntdll.dll 오류 해결방법 M 최고의하루 01.12 3659
3268 인터넷 동영상 저장하기 - 넷트랜스포터 사용 - M 최고의하루 01.12 3224
3267 옛날 기사를 찾아보고 싶을때 99 단국강토 01.08 2168
3266 CD 음악 mp3로 바꾸기 99 단국강토 01.08 2485
3265 알씨로 초간단 동영상 슬라이드쇼 만들기 99 단국강토 01.07 3310
3264 IP 추적은 어떻게 하는가? 99 단국강토 01.07 2212
3263 일본어로 된 웹을 한글로 즐기기 99 단국강토 01.06 2307
3262 [컴퓨터 키보드, 특수문자 정식 명칭들] M 최고의하루 12.18 3699
3261 하드,CPU,RAM 지원표 M 최고의하루 12.18 2583
3260 award bios 어워드 바이오스 설정법 M 최고의하루 12.18 3941
3259 내장 그래픽카드 죽이는 법 M 최고의하루 12.04 4877
3258 컴퓨터 조립 M 최고의하루 12.04 2829
3257 USB 버젼 속도 차이 2 천진난만 02.20 2374
3256 제가 사용하고 있는 마케팅프로그램입니다 댓글1 3 천지인 05.23 13191
마케팅
특별 마케팅자료
다운로드 마케팅자료
창업,경영
기획,카피,상품전략
동기부여,성취