好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>后端语言>PHP
<tfoot draggable='sEl'></tfoot>

php禁止重复登录 php防止再次刷新

很多站长朋友们都不太清楚php禁止重复登录,今天小编就来给大家整理php禁止重复登录,希望对各位有所帮助,具体内容如下:

本文目录一览: 1、 thinkphp添加用户禁止重复 2、 php怎么防止同一用户登陆 3、 PHP如何判断用户是否登陆,防止同账号多登陆, 4、 php如何防止程序重复执行 5、 Thinkphp5防止某个IP多次登录的方法 6、 请问php防止一个用户重复登录的问题 thinkphp添加用户禁止重复

thinkphp5.1实现避免用户重复登录问题

问题,只要用户登录了就直接跳转到首页

思路,实现就是一个初始化方法,然后控制器继承这个方法,运行就验证是不是有这个session存在

在控制器文件夹新建一个Base类文件

做一个if判断

class Base extends Controller

{

//防止重复登陆

protected function initialize()

{

if (!session('?admin.id')){//判断session是否有,有的话直接跳转

$this->redirect('admin/index/login');

}

}

}

然后在需要验证的控制器继承一下这个控制器

class Comment extends Base

{

登录后复制

就可以实现避免重复登陆

当然这个base的初始话方法可以写在任意一个类文件中就不需要再继承

php怎么防止同一用户登陆

表里加个时间,用户刷新一次网页更新一次时间,如果距上次刷新页面时间超过假如20分钟,就算自动退出了。

PHP如何判断用户是否登陆,防止同账号多登陆,

大概逻辑是这样的,如果要达到一个账号登陆了,要把另一个客户端上的统一账号踢掉,那么你需要用记录用户头token,和设备唯一识别号到数据库。

当用户登陆的时候,检测和用户uid相关的token表,如果已经有token了,并且本次的设备唯一识别号和已经登陆的识别号不一样,那么清空原有token,也就是将原来登陆的账号踢下线。记录新的设备识别号的token即可。

php大致代码如下:

$currentDeviceUUID=getDeviceUUID();

$uid = getUserId();

$token = generateToken();

select * from tokenTable where uid="$uid";

update set token=''  where uid="$uid";

insert into tokenTable (uid, token, deviceUUID) values("$uid", "$token", $currentDeviceUUID);

php如何防止程序重复执行

在用户表中加四个字段,一个记录是否登录,一个记录登录随机码(每次登录不一样),一个记录最后登录时间,一个记录登录ip,登录后保存user_id及登录随机码的session,在全局的配置文件中写一个方法.每次访问一个页面都去查询用户表的登录随机码及ip,如果发现ip或随机码不一致(因为同一局域网获取的ip可能一样,所以不能单纯的判断ip,加上验证随机码),则弹出提示消息,并清空session,强迫下线.

Thinkphp5防止某个IP多次登录的方法

//昨天写的思路不对,重新写....

/**

*检查IP是否重复登录多次

*/

public function check_ip(){

//获取ip

$login_ip=$_SERVER["REMOTE_ADDR"];

$login_time=date("Y-m-d",time());

if(Cache::get('cache_login_data')==false){

//如果ip换成为false,那么创建一个缓存,并赋值第一个

$login_data[0]=['login_ip'=>$login_ip,'login_time'=>$login_time];

Cache::set('cache_login_data',$login_data);

}else{

//如果有cache,那么将这条数据加入到缓存中最后一条去

$cache_login_data=Cache::get('cache_login_data');

$count=0;

foreach($cache_login_dataas$k=>$v){

//如果当前缓存中的值含有当前ip和时间,那么计算当前时间内登录次数

if($v['login_time']==$login_time$v['login_ip']==$login_ip){

$count++;

if($count>10){

//当前ip登录超过10次

$this->error("你登录超过了10次,请不要再来登了...","Login/index");

}else{

//当前时间内有该IP登陆过,但是没有超过10次

$cache_login_data[count($cache_login_data)+1]=['login_ip'=>$login_ip,'login_time'=>$login_time];

Cache::set('cache_login_data',$cache_login_data);

}

}else{

//当前时间内,该IP没有登陆过

$cache_login_data[count($cache_login_data)+1]=['login_ip'=>$login_ip,'login_time'=>$login_time];

Cache::set('cache_login_data',$cache_login_data);

}

}

}

}

请问php防止一个用户重复登录的问题

php的做法:

只能在每个页面通常是config.php更新该用户最后一次点击页面的时间,

同时查询哪些用户20分钟还没有点击,则删除。

====================更新

表名:use_log

uid int

lastrefer timestamp

用户每次点击任何一个页面,都会更新这个表的lastrefer为最新时间。

同时查询lastrefer小于当前时间-20分钟的用户,视为已经退出的用户。

补充2:参见php.ini设置

补充3:就是在config.ini里面

if(用户登录){

$sql="update 表 set lastrefer=CURRENT_TIMESTAMP WHERE 用户=当前用户"

执行sql

}

补充4:你这15分真难挣

关于php禁止重复登录的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。

查看更多关于php禁止重复登录 php防止再次刷新的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did195746
更新时间:2023-04-26   阅读:18次

上一篇: php按钮的代码 php界面代码

下一篇:html邮件php源码 html邮箱链接代码

最新资料更新

  • 1.php配置smtp php配置文件的文件名是什么
  • 2.php接收post php接收post数据在发出代码
  • 3.phpsql添加记录 php数据表里怎么添加数据
  • 4.扫描登录php代码 扫描登录php代码错误
  • 5.php数组逗号分隔 php中的输出语句 能使用逗号分隔多个表达式
  • 6.php会做流控吗 php流程控制
  • 7.php在线直播详解 php直播用的什么技术
  • 8.phpajix的简单介绍
  • 9.php好的入门书籍 php好的入门书籍在哪里
  • 10.如何阅读php源码 php在线源码获取
  • 11.php限制访问ip php访问被拒绝
  • 12.php中if应用 php中if语句
  • 13.php如何接收对象 php怎么接收json数据
  • 14.php数据抓取实例 php采集数据
  • 15.php网站设计素材 php网站制作
  • 16.php延迟0.1 php延迟执行不影响页面展示
  • 17.phpsessions phpsession使用
  • 18.php薪资1680 php一个月能挣多少钱
  • 19.php河内塔问题 河内塔算法
  • 20.php网站+iis php网站有哪些

CopyRight:2016-{hedonghua:year}{hedonghua:sitegs} 备案ICP:湘ICP备09009000号-16 {hedonghua:sitejym}
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]