이 글에서는 주로 PHP의 온라인 인원수 계산 기능을 소개하고 있으며, 세션 객체 계산을 기반으로 PHP의 관련 조작 기술을 분석하고, 도움이 필요한 친구들이 참고할 수 있는 형태로 온라인 인원수를 계산합니다.
이 기사의 예는 PHP 방식으로 온라인 사용자 수를 계산하는 구현을 보여줍니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
ASP에서는 애플리케이션 개체를 사용하여 온라인에 있는 사람 수를 계산할 수 있다는 것을 기억합니다. PHP를 디자인하는 방법?
PHP는 세션 개체를 매우 잘 캡슐화합니다. HTTP 프로토콜에 따라 각 웹 사이트 방문자는 고유 식별자를 생성할 수 있습니다.
echo session_id(); //6ed364143f076d136f404ed93c034201<br />
이는 온라인 사용자 수를 계산하는 열쇠입니다. 사람들을 방문하십시오. 모두가 다르기 때문입니다.
다음으로 세션 변수의 값을 데이터베이스에 저장하는 방법입니다. 여기서는 또 다른 함수를 소개하겠습니다
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) //垃圾回收函数
참고 위에는 매개변수가 전달된 여러 함수가 있습니다. 전송이 있음을 나타내기만 하면 됩니다. 그냥 입력하세요. PHP는 코드를 실행할 때 자동으로 세션의 매개변수를 읽습니다. 다음 단계는 위의 5개 함수와 주요 함수를 완료하는 것입니다. 그런데 왜 array("session", "method"를 사용합니까? ) 이러한 메서드를 호출하려면 정말 이해가 안 돼요
(기본적으로 이해합니다:객체의 모든 메서드는 매개 변수로 전달되므로 다음 형식을 사용해야 합니다: array(object, "메서드 이름"))
다음 단계는 각 함수를 작성하는 것입니다
session_set_save_handler( array("session","open"), array("session","close"), array("session","read"), array("session","write"), array("session","destroy"), array("session","gc") );
Close 데이터를 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_idfunction 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분간 조작이 없는 사용자 기록은 삭제됩니다
위 내용은 phg는 온라인 사용자 수를 어떻게 계산합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!