首页 > 开发 > PHP > 正文

判断在线用户的方法

2024-05-04 22:56:53
字体:
来源:转载
供稿:网友
解决了昨天的问题:表结果变了一下,如下:
create table tb_user (       --用户表
n_userid   number(5)      not null,       --用户id
v_nickname  varchar2(10)  not null,       --昵   称
v_pwd      varchar2(10)  not null,        --密   码
v_truename  varchar2(20),                 --姓   名
primary key (n_userid)
)
create table tb_onlineuser ( --在线用户
n_onlineuserid number(5)      not null,   --在线用户id
     d_logintime   number (16),       --登陆时间以秒计
     n_onlineid    number(5),   --与onlineusercount相关联。
    primary key (n_onlineid)
)
/
create table tb_onlineusercount (  --在线用户统计表
n_onlineid    number(5)      not null,   --系统id号
n_onlineuserid number(5)      not null,   --在线用户id
d_logindate    date                   ,          --登陆日期
d_logintime   number (16)    ,    --登陆时间以秒计
d_overdate      date    ,          --结束日期
d_overtime    number (16)             ,    --结束时间
     primary key (n_onlineid)
)
/

/*---loginselectnew.php---该程序是登陆检查程序----*/
<?
session_start();
/*思路:首先用户登陆,判断是否有该用户,判断是否密码通过,否则返回参数进行特殊处理。(登陆不成功)
  登陆成功后,如果该用户不在线(一般不在线,特殊情况如果他用另一台机器打开浏览器重新再登陆,那么他有可能在线),
  先进行session变量注册,取得相应条件向1.统计表与2.在线表中插数据。进入到登陆页。
  如果用户在线:先取得在线用户的系统id,因为在备份该用户离开时有用。接着删除该在线用户.接着进行该用户离开时间的备份.
*/
session_register("objsnickname");
require('oracle8conn.php');
$name=trim($name);
$pwd=trim($pwd);
ob_start();      //缓冲输出
$stmtnick = ociparse($conn,"select count(*) countnickname from tb_user where v_nickname='$name'");
ociexecute($stmtnick);
   while(ocifetchinto($stmtnick,&$arrn)){
     if ($arrn[0]==0){
           header("location:logintest.php?msg=1");
     }else{
           //用户名通过
           unset($arrnickname);           //撤消临时数组
           $stmtpwd = ociparse($conn,"select count(*) countpwd from tb_user where v_pwd='$pwd' and v_nickname='$name'");
           ociexecute($stmtpwd);
            while(ocifetchinto($stmtpwd,&$arrp,oci_num)){
              if ($arrp[0]==0){
                 header("location:logintest.php?msg=2");
            }else{//密码通过
    //取出用户的id号
       $stmtuid = ociparse($conn,"select n_userid from tb_user where v_nickname='$name'");
       ociexecute($stmtuid);
       while(ocifetchinto($stmtuid,&$arru,oci_num)){
            $intonlineuserid=$arru[0];          
       }//while_over    
    //如果该用户通过另一个浏览器重复登陆,解决如下
       $stmonlineflag=ociparse($conn,"select count(*) from tb_onlineuser where n_onlineuserid='$intonlineuserid'");
       ociexecute($stmonlineflag);     
       while(ocifetchinto($stmonlineflag,&$arronlineflag,oci_num)){
              if ($arronlineflag[0]!=0){                               //表示已经在线
                                                                      //先取到在线用户关联系统id
                  $stmtsysid= ociparse($conn,"select n_onlineid from tb_onlineuser where n_onlineuserid='$intonlineuserid'");
                  ociexecute($stmtsysid);
                  while(ocifetchinto($stmtsysid,&$arrsysid,oci_num)){
                      $sysid=$arrsysid[0];          
                   }//while_over                                     //找完后踢出该用户
                  $stmt = ociparse($conn, "delete from tb_onlineuser where n_onlineuserid='$intonlineuserid'");
                  ociexecute($stmt);
                  print "删除成功";                                  //最后作记录备份
                  $tmptime=time(); //结束时间
                  $datlogindate = date( "y-m-d");//结束日期
                  $datlogindate = "to_date('".$datlogindate."','yy/mm/dd')";
                  $stmtusercount = ociparse($conn, "update tb_onlineusercount set d_overdate=$datlogindate ,d_overtime=$tmptime where n_onlineid='$sysid'");//条件是相关联的系统id
                  ociexecute($stmtusercount);
                  print "添加成功到统计表中。";
                }//endif                                              //不在线正常注册
       $objsnickname=$name; //注册session变量
       unset($arrpwd);             //撤消临时数组
       srand((double)microtime()*1000000000);
       $intonlineid = rand();              //取一个系统id号
       $datlogindate = date( "y-m-d");    //取得系统日期存入到online表中去。
       $datlogintime = time();           //取系统时间
       $datlogindate = "to_date('".$datlogindate."','yy/mm/dd')";    
       $stmt = ociparse($conn, "insert into tb_onlineuser (n_onlineuserid,d_logintime,n_onlineid) values ($intonlineuserid,$datlogintime,$intonlineid)");
       ociexecute($stmt);
       $stmtc = ociparse($conn, "insert into tb_onlineusercount (n_onlineid,n_onlineuserid,d_logindate,d_logintime) values ($intonlineid,$intonlineuserid,$datlogindate,$datlogintime)");
       ociexecute($stmtc);
       header("location:index.php");  //成功登陆!
          }//whileover
        }//end if
      }//while_over
    }//end if
}//while_over

?>
<?ob_end_flush();?>
/*-------checksession-----检查刷新程序---*/
<?
/*30分钟刷新程序
  先统计出在线的用户数,如果没有在线用户,系统要保证一个系统指定用户。该系统用户时时在线的原因是保证该刷新程序的执行
  如果该登陆用户session不存在了,表示用该用户离线。统计出时间。
*/
  session_start();
  require('oracle8conn.php');
  print $objsnickname;
?>
  <html><head><meta http-equiv=refresh content='1800;url="checksession.php"'>
<?
$nowdate = date("y-m-d");
$nowdate = "to_date('".$nowdate."','yy/mm/dd')";
$nowtime = time();
//统计在线人数。30分钟更新一次
$stmtcount = ociparse($conn,"select count(*) from tb_onlineuser");
ociexecute($stmtcount);
while(ocifetchinto($stmtcount,&$arrcountuser)){
$countuser=$arrcountuser[0];
}
print "目前在线人数为:".$countuser."<br>";
//判断在线否?
if ($countuser==0){
   print "没有人在线!特殊处理!";
}else{
$stmtonlineuser = ociparse($conn,"select n_onlineuserid,d_logintime,n_onlineid from tb_onlineuser");
ociexecute($stmtonlineuser);
$arrtest = array();
while(ocifetchinto($stmtonlineuser,&$arruser[])){
    $arrtest += $arruser;
}
$j = sizeof($arrtest);
if($j>0){
    $i = sizeof($arrtest[0]);     
  }
}    
   for($b=0;$b<$j;$b++){  //因为存入二维数组中,所以双重循环。
    for($a=0;$a<1;$a++){ //内循环一次找到时间。
    //注意双循环中是为了取数组值
    // $arrtest[$b][0]  表示用户id
    // $arrtest[$b][1]  表示登陆起的时间
    // $arrtest[$b][1]  关联系统id
     if  (ceil(($nowtime-$arrtest[$b][1])/60)>300){ //如果当前时间与一条记录的旧时间相差大于30分钟。
         if ($objsnickname==""){  //如果此用户session不存在,表示已经退出。
         //删掉。
          $temglid= $arrtest[$b][2];   //关联系统id
          $temuserid= $arrtest[$b][0]; //用户id
          $stmt = ociparse($conn, "delete from tb_onlineuser where $intonlineid='$temglid' and n_onlineuserid='$temuserid'");
          print  "delete from tb_onlineuser where $intonlineid='$temglid' and n_onlineuserid='$temuserid'";
          ociexecute($stmt);
          print "删除成功";
         //添加到统计表中
          $tmptime=time(); //结束时间
          $datlogindate = date( "y-m-d");//结束日期
          $datlogindate = "to_date('".$datlogindate."','yy/mm/dd')";
          $stmtusercount = ociparse($conn, "update tb_onlineusercount set d_overdate=$datlogindate ,d_overtime=$tmptime where n_onlineid='$temglid'");//条件是相关联的系统id
          ociexecute($stmtusercount);
          print "添加成功到统计表中。";
         }else{
          $tmptime=time(); //取得临时用户时间
          $temuserid= $arrtest[$b][0];
          $stmt = ociparse($conn, "update tb_onlineuser set d_logintime=$tmptime where n_onlineuserid='$temuserid'");
          ociexecute($stmt);
          print "更新成功";
          print $tmptime;
        }
        }else{
         print session_id();
         print "系统时间:".$nowtime."<br>";
         print "数据库中旧时间:".$arrtest[$b][1]."<br>";
         print "用户id:".$arrtest[$b][0]."<br>";
         print "相差时间:".ceil(($nowtime-$arrtest[$b][1])/60)."<br>";
     }  
   }
}

/*如果要欢察统计表与在线表用户时间(当用户未离线时)
  select a.d_logintime,b.d_logintime from tb_onlineuser a,tb_onlineusercount b
  where a.n_onlineid=b.n_onlineid; 相差
   如果要统计出指定用户在线时间(当用户离线时)
  select d_logintime,d_overtime from tb_onlineusercount where n_onlineuserid='$userid'; 相差
*/

?>

                      谢谢你的帮助!:_)

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表