仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 550|回复: 18
打印 上一主题 下一主题

[学习教程] PHP编程:判别在线用户的办法

[复制链接]
柔情似水 该用户已被删除
跳转到指定楼层
#
发表于 2015-2-3 23:53:53 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
php   manual(PHP手册)肯定是要从网上下载一个的,它很权威,也很全面,我自己认为它是一本很好的参考书,但是不适合新手当教材使用。在线   处理了昨天的成绩:表了局变了一下,以下:
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'; 相差
*/

?>

                      感谢你的匡助!:_)

  开发相册系统过程中就有过这样的问题,因为没有交流好,出现重复工作问题,因为文档没有详细的说明而经常临时问对方。
山那边是海 该用户已被删除
18#
发表于 2015-6-6 09:24:01 | 只看该作者
实践是检验自己会不会的真理。
若天明 该用户已被删除
17#
发表于 2015-5-8 00:25:45 | 只看该作者
爱上php,他也会爱上你。
因胸联盟 该用户已被删除
16#
发表于 2015-5-7 14:57:36 | 只看该作者
最后介绍一个代码出错,但是老找不到错误方法,就是 go to wc (囧),出去换换气没准回来就找到错误啦。
15#
发表于 2015-5-2 11:37:19 | 只看该作者
这些中手常用的知识,当你把我说的这些关键字都可以熟练运用的时候,你可以选择自己
老尸 该用户已被删除
14#
发表于 2015-4-22 01:22:28 | 只看该作者
这些都是最基本最常用功能,我们这些菜鸟在系统学习后,可以先对这些功能深入研究。
只想知道 该用户已被删除
13#
发表于 2015-4-21 19:43:35 | 只看该作者
其实没啥难的,多练习,练习写程序,真正的实践比看100遍都有用。不过要熟悉引擎
愤怒的大鸟 该用户已被删除
12#
发表于 2015-4-11 01:11:22 | 只看该作者
为了以后维护的方便最好是代码上都加上注释,“予人方便,自己方便”。此外开发文档什么的最好都弄齐全。我觉得这是程序员必备的素质。虽然会消耗点很多的时间。但是确实是非常有必要的。
谁可相欹 该用户已被删除
11#
发表于 2015-3-28 01:32:43 | 只看该作者
本人接触php时间不长,算是phper中的小菜鸟一只吧。由于刚开始学的时候没有名师指,碰过不少疙瘩,呗很多小问题卡过很久,白白浪费不少宝贵的时间,在次分享一些子的学习的心得。
飘灵儿 该用户已被删除
10#
发表于 2015-3-27 21:11:37 | 只看该作者
我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。
精灵巫婆 该用户已被删除
9#
发表于 2015-3-26 03:43:23 | 只看该作者
装在C盘下面可以利用windows的ghost功能可以还原回来(顺便当做是重转啦),当然啦我的编译目录要放在别的盘下,不然自己的劳动成果就悲剧啦。
简单生活 该用户已被删除
8#
发表于 2015-3-18 16:36:35 | 只看该作者
多看优秀程序员编写的代码,仔细理解他们解决问题的方法,对自身有很大的帮助。
小妖女 该用户已被删除
7#
发表于 2015-3-11 13:58:36 | 只看该作者
Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81
爱飞 该用户已被删除
6#
发表于 2015-3-6 22:13:58 | 只看该作者
最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。
再现理想 该用户已被删除
5#
发表于 2015-3-6 19:13:05 | 只看该作者
Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81
活着的死人 该用户已被删除
地板
发表于 2015-2-20 23:59:34 | 只看该作者
对于懒惰的朋友,我推荐php的集成环境xampp或者是wamp。这两个软件安装方便,使用简单。但是我还是强烈建议自己动手搭建开发环境。
不帅 该用户已被删除
板凳
发表于 2015-2-9 03:43:49 | 只看该作者
个人呢觉得,配wamp 最容易漏的一步就是忘了把$PHP$目录下的libmysql.dll拷贝到windows系统目录的system32目录下,还有重启apache。
兰色精灵 该用户已被删除
沙发
发表于 2015-2-6 21:14:45 | 只看该作者
我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。
乐观 该用户已被删除
楼主
发表于 2015-2-4 16:25:23 | 只看该作者
因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-9-21 00:33

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表