이 글에서는 주로 PHP의 온라인 인원수 계산 기능을 소개하고 있으며, 세션 객체 계산을 기반으로 PHP의 관련 조작 기술을 분석하고, 도움이 필요한 친구들이 참고할 수 있는 형태로 온라인 인원수를 계산합니다.
ASP에서는 온라인 사용자 수를 계산하는 데 응용 프로그램이 사용된다는 것을 기억합니다. PHP를 디자인하는 방법?
PHP는 HTTP 프로토콜에 따라 각 웹사이트 방문자가 고유 식별자를 생성할 수 있도록 세션 개체를 매우 잘 캡슐화합니다. session_id는 방문자를 구별할 수도 있습니다. 모든 사람이 다르기 때문입니다.
다음으로, 세션 변수의 값을 데이터베이스에 저장하는 방법입니다. 여기에 또 다른 함수echo session_id(); //6ed364143f076d136f404ed93c034201<br />
가 있습니다. 위에는 매개변수가 전달된 여러 함수가 있습니다. 수신 전송입니다. PHP가 코드를 실행하면 자동으로
session의 매개변수를 읽습니다. 다음 단계는 위의 5개 함수와 주요 함수
bool session_set_save_handler ( callable $open , callable $close , callable $read , callable $write , callable$destroy , callable $gc )
//callable 可随时支取的,请求即付的,随时可偿还的
// open(string $savePath, string $sessionName) 打开连接
//close() 关闭连接
//read(string $sessionId) 对出数据
//write(string $sessionId, string $data) //写入数据
//destroy($sessionId) //删除数据
//gc($lifetime) //垃圾回收函数
주 함수는 다음과 같이 완성됩니다. 그런데 왜 이러한 메소드를 호출하기 위해 array("session", "method")를 사용해야 할까요?
(기본적으로 이해하세요:
객체의 모든 메소드는 매개변수로 전달됩니다. 다음 형식을 사용하세요: array(object , "method name"))
다음 단계는 각 함수를 작성하는 것입니다
session_set_save_handler(
array("session","open"),
array("session","close"),
array("session","read"),
array("session","write"),
array("session","destroy"),
array("session","gc")
);
닫은 데이터를 close
//链接数据的open function open($path,$sessname) { $db = mysql_connect("localhost","root","123456","test"); mysql_select_db("test",$db); mysql_query("SET NAMES UTF8"); return true; }
연결할 수 있습니다. 시작하려면 읽기 함수 read( )를 표시합니다. 주로 read() 함수에는 전달된 값이 있습니다. 전달되는 것은 session_id
function close(){ $db = mysql_connect("localhost","root","123456","test"); mysql_close($db); return true; }
두 번째는 쓰기 함수입니다. 새로운 데이터 쓰기
function read($sid){ $sql = "select data from session where sid='{$sid}' and card='".self::$card."'"; $query = mysql_query($sql) or die(mysql_error()); $row = mysql_fetch_array($query); $row>0?$row["data"]:" "; }
다음 단계는 PHP 재활용 메커니즘을 구현하는 함수입니다. 두 함수 모두 매개변수가 전달됩니다.
function write($sid,$data) { $sql = "select sid from session where sid='{$sid}' and card='".self::$card."'"; $query = mysql_query($sql) or die(mysql_error()); $mtime = time(); $num = mysql_num_rows($query); if($num){ $sql = "UPDATE session SET data='{$data}', mtime ='{$mtime}'"; }else{ $sql = "INSERT INTO session (sid,data,mtime,ip,card) VALUES('{$sid}','{$data}','".time()."','{$_SERVER['REMOTE_ADDR']}','".self::$card."')"; } mysql_query($sql); return true; }
자, 다섯 가지 함수가 완성되고 세션 테이블에서 세션 레코드의 개수를 읽어옵니다. 페이지를 방문하는 사람의 수를 정확하게 계산할 수 있습니다.
10분 동안 조작하지 않은 사용자 기록은 삭제됩니다
요약: 위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되길 바랍니다.
관련 권장사항:
PHP 공통 함수 모음php Yield의 역할
위 내용은 온라인 인원수 계산 기능을 구현하는 PHP 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!