php登录踢,PHP会员登录,和判断用户权限,登录超时踢除用户

php100视频里的一个会员登录系统实例,虽然很小,但里面的一些基本功能实现还是不错的,

分为三个文件,如下:

config.php

session_start();

$conn=mysql_connect('localhost','root','a123456') or die("连接错误");

mysql_select_db("xuexi",$conn) or die("数据库错误");

mysql_query("set names'utf8'");

define(ALL_PS,"ljzhen");//为ljzhen在做加密,保证用户的安全性。

function user_shell($uid,$shell,$yid){ //这里定义了变量

$sql="select * from login_user where `uid`='$uid'";

$query=mysql_query($sql);

$us=is_array($row=mysql_fetch_array($query));

$shell=$us ? $shell=md5($row[username].$row[userpass].ALL_PS) :FALSE;

if($shell){

if($row[yid]<=$yid){ //判断用户权限,条件满足时,即可访问该页面

return $row;

}else{

echo "你的权限不足,无法访问该那面";

echo "返回【查看权限】重新登陆";

exit();

}

}else{

echo "你无权限访问该页面!";

echo "返回重新登陆";

exit();

}

}

function user_mktime($onlinetime){

$new_time=mktime();

echo $new_time-$onlinetime; //当前时间减去用户登陆时间

if($new_time-$onlinetime>'100'){ //判断登陆时间超过我们制定时间后,自动踢出!

echo "登陆超时";

session_destroy();//清除session中的值

exit();

}else{

$_SESSION[times]=mktime(); //及时更新时间,即用户有操作页面时,重新计算时间

}

}

?>

login.php

include("config.php");

@header("content-type:text/html; charset=UTF-8");

//

//echo md5("admin".ALL_PS);//采用admin和前面的LJZHEN同时加密

if($_POST[submit]){

$username=str_replace(" ","",$_POST[username]);

$sql="select * from login_user where `username`='$username'";

$query=mysql_query($sql);

$us=is_array($row=mysql_fetch_array($query));//这里判断用户名是否为真

$ps= $us ? md5($_POST[password].ALL_PS)==$row[userpass] : FALSE;//这里判断用户名和密码是否为真

if($ps){ //这里对$ps进行判断

$_SESSION[uid]=$row[uid]; //获取ID存入SESSION

$_SESSION[user_shell]=md5($row[username].$row[userpass].ALL_PS); //这里在对用户和密码进一层加密

$_SESSION[times]=mktime();

echo "登陆成功,点击【进入】操作";

}else{

echo "用户名或密码错误!";

session_destroy();

}

}

?>

//echo $_SESSION[uid];

//echo $_SESSION[uname];

?>

用户:

密码:

login_sys.php

include("config.php");

@header("content-type:text/html; charset=UTF-8");

//$_SESSION[uid];

//$_SESSION[user_shell];

$arr=user_shell($_SESSION[uid],$_SESSION[user_shell],1); //获取登陆用户信息--2是表示用户的权限设置的

//echo $arr[username]."
";

user_mktime($_SESSION[times]); //使用user_mktime类方法

if($_GET[out]){ //注销当前用户

unset($_SESSION[uid]);

unset($_SESSION[user_shell]);

echo"

location.href='login_sys.php'

// -->";//刷新当前页面

}

echo "退出";

?>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP nb-808通讯协议开锁主要是通过使用PHP编程语言来实现对nb-808设备的通信和控制。nb-808设备是一种用于开锁的无线通信设备,可以通过手机或其他智能设备发送指令来控制开锁动作。 在编程实现通讯协议开锁的过程中,首先需要建立与nb-808设备的通信连接。可以使用PHP的网络编程库或者使用HTTP请求的方式来与设备进行通信。通常,对于nb-808设备来说,使用HTTP协议来发送和接收指令比较常见。 在发送开锁指令之,需要先验证用户的权限和身份。可以通过向nb-808设备发送验证指令,并检查设备返回的响应来确认用户的合法性。如果验证成功,则可以继续执行开锁操作。 开锁指令通常是通过向nb-808设备发送一段特定的命令字符串来实现的。可以通过PHP的字符串处理函数来构建并发送开锁指令。指令包括设备地址、指令类型、参数等内容,这些内容需要按照通讯协议的规定进行组装和编码。 发送开锁指令后,可以通过等待一段时间来检查设备的响应情况。设备可能会返回开锁成功或者失败的信息,可以根据设备返回的响应来判断开锁操作是否成功。 在通讯协议开锁的过程中,还需要考虑异常处理和错误处理。例如,网络连接失败、用户权限验证失败、设备响应超时等情况都需要进行相应的处理和提示。 总之,通过使用PHP编程语言和nb-808通讯协议,可以实现对nb-808设备的开锁功能。这需要建立通信连接、验证用户权限、构建并发送开锁指令,并处理设备的响应情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值