首页 > 作文

php 实现账号不能同时登陆的方法分析【当其它地方登陆时,当前账号失效】

更新时间:2023-04-08 15:32:54 阅读: 评论:0

本文实例讲述了php 实现账号不能同时登陆的方法。分享给大家供大家参考,具体如下:

解决的思路是每当用户登陆时我们必需记录当前的用户id和ssion_id,如果有人在其它地方用此账号登陆时,我们把此用户id对应的ssion_id的ssion文件删除,并重新记录当前的ssion_id。那么之前的用户就失效了。

login.php代码如下:

<?phpssion_start(); require 'db.php'; if(!empty($_post['submit'])) {  $uname = !empty($_post['uname']) ? trim($_post['uname']) :反法西斯阅兵 '';  $upwd = !empty($_post['upwd']) ? trim($_post['upwd']) : '';   //这里只是演示,实际情况是在数据库里查询并判断  if($uname == 'test' && $upwd == 'test') {    //这里假设test用户id为1    $uid = 1;    $ssion_id = ssion_id();         //判断是否已有用户登陆过    $res = mysql_query("lect ssion_id from tb_login_state where uid={$uid}");    $data = mysql_fetch_assoc($res);    if(!empty($data)) {      $ssionid = $data['ssion_id'];      $ssionfilepath = ssion_save_path() . directory_parator . 'ss_' . $ssionid;       //删除上次用户登陆的ssion文件      if(file_exists($ssionfilepath) && is_writable($ssionfilepath)) {        @unlink($ssionfilepath);      }      //删除用户登陆信息      mysql_query("delete from tb_login_state where uid={$uid}");    }    //添加新的用户登陆信息    mysql_query("inrt into tb_login_state values({$uid}, '{$ssion_id}')");     $_ssion['urinfo'] = array(      'name' => $uname    );    echo '<script type="text/javascript">alert("您已成功登陆,跳转首页");</script>';    echo '<script type="text/javascript"&g中秋节吃月饼的来历简单介绍t;location.hre内流河f="index.php" rel="external nofollow" ;</script>';  }}?><!doctype html><html lang="zh-cn"><head>  <meta chart="utf-8">  <title>用户登陆页面</title></head><body>  <form action="" method="post">    用户名:<input type="text" name="uname" value="" />    密码:<input type="password" name="upwd" value="" />    <input type="submit" name="submit" value="登陆" />  </form></body></html>

index.php代码如下:

<?phpheader('content-type:text/html;chart=utf-8');ssion_start(); if(!empty($_ssion['urinfo'])) {  echo '您好:', $_ssion['urinfo']['name']纯物质;} el {  header('location:login.php');}

db.php代码如下:

<?php$db = mysql_connect('127.0.0.1','root','') or die('connect error');mysql_lect_db('test') or die('lect db error');mysql_query('t names utf8') or die('t names error');

tb_login_state表结构如下:

create table `tb_login_state` (`uid` int(11) unsigned not null comment '用户id',`ssion_id` varchar(32) not null default '' comment '存储用户的ssion_id') engine=innodb default chart=utf8 comment='用户登陆状态表';

如果是ssion存储方式不是文件,而是存在mysql,memcache,redis中,思路其实是一样的,都是把前一次的ssion_id保存。判断用户是否登陆过,如果登陆过就让上一次的ssion失效(删除ssion数据)。

(*通过设置ssion的过期时间和cookie的过期时间来让ssion失效是不严格的,最直接的方法是直接把ssion文件删除。)

推荐阅读:

/d/file/titlepic/2831.html

本文发布于:2023-04-08 15:32:51,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/1e4c59f123bc79c9335a72a36a30a2c5.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:php 实现账号不能同时登陆的方法分析【当其它地方登陆时,当前账号失效】.doc

本文 PDF 下载地址:php 实现账号不能同时登陆的方法分析【当其它地方登陆时,当前账号失效】.pdf

标签:用户登陆   用户   文件   代码
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图