限制登录人数

$user_online = "./text.php"; //保存人数的文件,可以是txt、php,json文件
touch($user_online);//如果没有此文件,则创建
$timeout = 3600;//30秒内没动作者,认为掉线
$user_arr = file_get_contents($user_online);//读取文件内容
$temp = array();//将要重新保存的数据;
$ip = session_id() ;//session_id(),每个访问者的session_id 都是唯一的;
$check = 0;
if ($user_arr != '') {
    $user_arr = explode('#', rtrim($user_arr, '#'));//用#来分割数组中的每个成员的信息;
    foreach ($user_arr as $value) {
        $checkuser = explode(",", trim($value));//用,来分割每个成员的ip和访问时间;
        if (($checkuser[0] != $ip) && ($checkuser[1] > time())) {//如果不是本用户IP并且时间没有超时则放入到数组中
            array_push($temp, $checkuser[0] . "," . $checkuser[1]);
            $check++;
        }
    }
}
if ($check > 0) {
    var_dump('超出登录人数限制');
    die();
};
array_push($temp, $ip . "," . (time() + ($timeout)) . '#'); //保存本用户的信息
$user_arr = implode("#", $temp);
//写入文件
$fp = fopen($user_online, "w");
flock($fp, LOCK_EX); //flock() 不能在NFS以及其他的一些网络文件系统中正常工作
fputs($fp, $user_arr);
flock($fp, LOCK_UN);
fclose($fp);

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章