+ -
当前位置:首页 → 问答吧 → php实现登陆后台 限制到只允许一台机器在线 要求加精

php实现登陆后台 限制到只允许一台机器在线 要求加精

时间:2009-06-23

来源:互联网

[php]
<?php
ob_start();
session_start();
class CC{
  private $REFURL="http://www.cncms.com.cn";    //登陆成功后转换页面
  private $LoginFLAG=false;        //登陆成功标志
  private $loginFILE="loginmsg.txt";      //信息文件
  function setFlag($flag){
    $this->loginFLAG=$flag;
  }
  function check(){
  global $_POST;
    if(file_exists($this->loginFILE)&& (time()-filemtime($this->loginFILE))<60){//用户登陆存在而且有效
      $info=file($this->loginFILE);
      $username=trim($info[0]);  //已在线的登陆用户名
      $password=trim($info[1]);  //已在线密码(可以不保存)
      $ip   =trim($info[2]);  //已在线IP
      $sid   =trim($info[3]);  //已在线PORT
      if(strcmp($_SESSION[LoginUser],$username)==0){
        if(strcmp($_SESSION['LoginPw'],$password)==0){
          if(strcmp($_SERVER[REMOTE_ADDR],$ip)==0){
            if(strcmp(session_id(),$sid)==0){
              $this->setFlag(true);
              echo "<h3>您的帐户可以确定是唯一的!</h3>";
              $cf=fopen($this->loginFILE,"a+");
              fputs($cf,"\r\na");
              fclose($cf);
              echo "<meta http-equiv=refresh content=\"10;url=t.php\">";
              //echo "<iframe src=\"t.php\" frameborder=0 width=0 height=0></iframe>";
            }else{
              echo "不允许帐户在局网上同时登陆.. ".$_SERVER[REMOTE_PORT];
              $this->LoginFLAG=false;
            }       
          }else{
            echo "不允许使用帐户同时登陆..<br>";
              $this->LoginFLAG=false;
          }
        }else{
          echo "密码错误..<br>";
          $this->LoginFLAG=false;
        }
      }else{
      //这里验证身份如果正确则
        echo "帐户登陆时发生错误!用户名错误<br><pre>";
      }
    }else{
      if(isset($_POST[LoginUser])){
        $_SESSION[LoginUser]=$_POST[LoginUser];
        $_SESSION[LoginPw]=$_POST[LoginPw];
        $fp=fopen($this->loginFILE,"w");
        $msg=$_POST['LoginUser']."\r\n".$_POST['LoginPw']."\r\n".$_SERVER[REMOTE_ADDR]."\r\n".session_id();;
        fputs($fp,$msg);
        fclose($fp);
      }else{
        $outtime=time()-filemtime($this->loginFILE)-60;
        echo "登陆不存在或您已经超时(".$outtime."秒)...";
      }
    }
  }
  function Wfrom(){
  global $_POST;
  if(!file_exists($this->loginFILE) ||(time()-filemtime($this->loginFILE))>60){    //登陆失败
  echo <<<LOGINFORM
  <Form action="$_SERVER[PHP_SELF]" method="post" name="Loginform">
    <table cellpadding=0 border=0>
    <tr><td>
    用户名:<td><input type="text" name="LoginUser"></span><br>
    <tr><td>密码:<td><input type="password" name="LoginPw"></span><br>
    <tr><td> <td><input type="button" value=" Login " onclick="if(this.form.LoginUser.length*this.form.LoginPw.length!=0){this.form.submit();}else{return false;}">
    </table>
  </form>
LOGINFORM;
  }else{
    echo "已有用户登陆";
  }
  }
}
$D=new CC;
$D->check();
$D->Wfrom();
?>
[/php]

作者: wyjboy   发布时间: 2009-06-23

哈哈

作者: php100.org   发布时间: 2009-06-24

很好,值得看看!

作者: gaogao   发布时间: 2009-06-24

作者: aluo   发布时间: 2009-06-24

怎么复制不了呢?

作者: yeyu21   发布时间: 2009-06-25

可以复制!

作者: wang7dao   发布时间: 2009-06-25

哈哈

作者: wyjboy   发布时间: 2009-06-25

不错,支持一个!

作者: xiaokai   发布时间: 2009-06-26

看看啊。。。

作者: aivyzh5   发布时间: 2009-06-26

据目测结果,这个貌似无法达到效果

类在实例化的时候,所生成的登录标记并非是同一个东东

按本人思路,将这个标记以及登录时间存入数据库,每次登录时候取出才可行


一己之见,如有差错,LZ请明示

作者: jmone   发布时间: 2009-06-26

看似不错···········

作者: qingshuihe   发布时间: 2009-07-06

kkkkkkkkkkkkkkkkkk

作者: test1112   发布时间: 2009-11-10

学习哈。

作者: 95379448   发布时间: 2009-12-23

谢谢分享!!!!

作者: litwin   发布时间: 2010-01-19

热门下载

更多