PHP でユーザーのオンライン時間をカウントする方法の説明:
まず、関連するデータ テーブル構造、つまり 4 つのフィールドを紹介します:
コードは次のとおりです:
uid
session_id
login_time
logout_time
1. クライアントはサーバーに定期的にリクエストを送信します。実装方法は、ユーザーがログインした後のレコードに uid、session_id、login_time を挿入し、クライアント JS でタイマーを設定します。たとえば、ログアウトを更新する目的を達成するために 10 分ごとにサーバーにリクエストを送信します。もちろん、この間隔を短く設定するとデータの精度は高くなりますが、対応するシステム負荷は実際の状況に基づいて適切な値に設定できます。このメソッドは、Web ゲームで広く使用されています。Web ゲームのほとんどすべてのリクエストが Ajax リクエストであり、ページが更新されるとタイマーの値が失われるためです。これがこのメソッドの制限でもあります。
2. サーバー上でスケジュールされたポーリング スクリプトを設定します。この方法は、サーバー側でスケジュール実行スクリプトを記述し、例えば5分に1回実行し、各セッションのsession_idがサーバー上に存在するかどうかをデータベース内のレコードに基づいて判断します。 、logout_time が存在しない場合はスキップされます。これによりオンライン時間を正確にカウントすることもできますが、サーバーを制御する必要があるという欠点があります。そうでないと、Linux システムでは crontab を介してタイミング スクリプトを設定でき、Windows システムではスケジュールされたタスクを介してこれを実行できます。仮想ホストを購入したばかりの場合、この方法も適していません。
3. ユーザーがアクティビティを実行するたびにログアウト時間を更新します。このように、ユーザーが非アクティブであるかログアウトすると、ログアウト時刻がデータベースに自然に存在します。これは、この記事で焦点を当てている解決策でもあります。実装方法は以下の通りです。
まず、ユーザーが正常にログインした後、ユーザーの uid と session_id を記録し、現在時刻をログイン時刻として使用し、現在の時刻 600 秒をログアウト時刻として使用して、データベースに挿入します。
コードは次のとおりです:
$uid = $_SESSION[uid] = $info[id];
$session_id = $_SESSION[session_id] = session_id();
$login_time = time();
$logout_time = time () 600 ;
$sql = "INSERT INTO member_login (uid,session_id,login_time,logout_time)values($uid,$session_id,$login_time,$logout_time)";
mysql_query($sql);
その後、毎回つまり、ページがクリックされるたびに、セッションが存在する場合、つまりユーザーがログインしている場合、ユーザーのログアウト時間が更新されます。 コードは次のとおりです:
if($_SESSION[uid]) {
$uid = $_SESSION[uid];
$session_id = $_SESSION[session_id];
$logout_time = time() 600;
$sql = "update member_login SET logout_time=$logout_time WHERE uid=$uid AND session_id= $session_id";
mysql_query($sql);
}
この方法の利点は、実装が比較的簡単で、ほとんどの Web サイトに適用でき、追加のサーバー要件がなく、ユーザーのオンライン数も正確にカウントできることです。時間。
データベースの更新操作が増加し、システムの負荷が増加するというデメリットもありますが、中小規模の Web サイトでは問題になりません。