php实现登陆后台 限制到只允许一台机器在线 要求加精
时间:2009-06-23
来源:互联网
<?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
作者: test1112 发布时间: 2009-11-10
作者: 95379448 发布时间: 2009-12-23
作者: litwin 发布时间: 2010-01-19
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28