中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > Linux编程
用php实现登陆界面限制到只允许一台机器在线
作者:佚名 时间:2007-11-07 16:51 出处:互连网 责编:月夜寒箫
              摘要:用php实现登陆界面限制到只允许一台机器在线
  <?phpob_start();session_start();class CC{

  private $REFURL="http://www.abc.com";

  //登陆成功后转换页面

  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,"

  a");

  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']."

  ".$_POST['LoginPw']."

  ".$_SERVER[REMOTE_ADDR]."

  ".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();?>

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有