• 技术文章 >后端开发 >PHP问题

    php怎么禁止重复登录

    藏色散人藏色散人2021-05-17 09:27:29原创270

    php禁止重复登录的方法:1、获得当前打开浏览器session的id;2、判断数据库里的session_id与当前session_id是否相等,如果不相等则需要跳转重新登录。

    本文操作环境:Windows7系统、PHP7.1版,DELL G3电脑

    php防止用户重复登录

    先来理解一下session的几个设置:

    ini_set('session.auto_start',0);

    设置关闭session的自动启动

    ini_set('session.cookie_lifetime',0);

    设置session在浏览器关闭时失效,session默认情况下是这样子的,无需在设置

    ini_set('session.gc_maxlifetime',3600);

    设置session在浏览器未关闭时的持续存活时间

    大概知道上面的几个设置,那么我们开始理解下今天的内容啦。每当一个用户登一个账号时候,他打开浏览器就会自动生成一个session_id(有效时间内是唯一的),然后我们把这个唯一的id存入到user表的去(每登录一次就更新一次当前账号user表中的session_id的值)。这样,在登录后的所有界面都需要判断,当前浏览器的session_id()与数据库的user表的session_id是否一致,如果不一致,则显示当前账号已在线,你需要再次登录再可以顶掉他的登录。(就是每一次只能一个用户登录,后面登录的用户会挤掉前面登录该账号的用户)

    详细,我们看下代码吧:(其他无关本次推文代码的代码,我就不细说啦)

    8718a33faa90da2fdc8e12ef9d77a4f.png

    第一个框:获得当前打开浏览器session的id,为下面插入、更新数据库里唯一的session_id做准备

    第二个框:判断,数据库里的session_id与当前session_id是否相等,若不相等,则更新当前数据库里的session_id,若相等,直接返回3到前端ajax

    9d9e3a4781b82d20aaf4c9a1f95df62.png

    在index.php界面下,这个框,表示判断当前session_id()与数据库的session_id是否相等,如果不相等,则表示当前账号已经有登录,且session_id不相等,需要跳转重新登录。

    推荐学习:《PHP视频教程

    以上就是php怎么禁止重复登录的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:php
    上一篇:php exit 用法是什么 下一篇:wdcp怎么安装php5.5
    VIP会员

    相关文章推荐

    • php怎么判断字符串含不含中文• php怎么将字符串转为timestamp(时间戳)• centos安装php开发环境• godaddy怎么修改php版本

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网