侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

PHP利用Cookie设置用户30分钟未操作自动退出功能

php  /  管理员 发布于 7年前   152

登陆控制器需要做的登陆成功把用户ID等信息存入cookie:

$this->systemSetKey(array(‘name‘=>$admin_info[‘admin_name‘], ‘id‘=>$admin_info[‘admin_id‘],‘gid‘=>$admin_info[‘admin_gid‘],‘sp‘=>$admin_info[‘admin_is_super‘]));//登陆成功之后做得事情

父类中的 systemSetKey 方法:

 /**   * 系统后台 会员登录后 将会员验证内容写入对应cookie中   *   * @param string $name 用户名   * @param int $id 用户ID   * @return bool 布尔类型的返回结果   */  protected final function systemSetKey($user){    setNcCookie(‘sys_key‘,encrypt(serialize($user),MD5_KEY),3600,‘‘,null);//设置cookie 过期时间为30分钟。这边设置cookie框架有带自己加密规则,具体是否需要加密自己看着设置。  }

父类控制器构造方法判断用户是否有登陆:

protected function __construct(){    Language::read(‘common,layout‘);    /**     * 验证用户是否登录     * $admin_info 管理员资料 name id     */    $this->admin_info = $this->systemLogin();//取得管理员的资料,之后的子类控制器继承构造方法    if ($this->admin_info[‘id‘] != 1){      // 验证权限      $this->checkPermission();    }    //转码 防止GBK下用ajax调用时传汉字数据出现乱码    if (($_GET[‘branch‘]!=‘‘ || $_GET[‘op‘]==‘ajax‘) && strtoupper(CHARSET) == ‘GBK‘){      $_GET = Language::getGBK($_GET);    }  }  /**   * 系统后台登录验证   *   * @param   * @return array 数组类型的返回结果   */  protected final function systemLogin(){    //取得cookie内容,解密,和系统匹配    $user = unserialize(decrypt(cookie(‘sys_key‘),MD5_KEY));//取cookie 里面储存的信息,现在使用的框架里面自定义了cookie的加密方式    if (!key_exists(‘gid‘,(array)$user) || !isset($user[‘sp‘]) || (empty($user[‘name‘]) || empty($user[‘id‘]))){  //假如不存在说明用户没登陆或者用户长时间未操作cookie时间过期 跳到登陆页面去      @header(‘Location: index.php?mod=login&action=login‘);exit;    }else {      $this->systemSetKey($user);//如果用户有登陆的话,每一个操作都会重写刷新cookie;    }    return $user;  }

加密函数:

/** * 加密函数 * * @param string $txt 需要加密的字符串 * @param string $key 密钥 * @return string 返回加密结果 */function encrypt($txt, $key = ‘‘){  if (empty($txt)) return $txt;  if (empty($key)) $key = md5(MD5_KEY);  $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.";  $ikey ="-x6g6ZWm2G9g_vr0Bo.pOq3kRIxsZ6rm";  $nh1 = rand(0,64);  $nh2 = rand(0,64);  $nh3 = rand(0,64);  $ch1 = $chars{$nh1};  $ch2 = $chars{$nh2};  $ch3 = $chars{$nh3};  $nhnum = $nh1 + $nh2 + $nh3;  $knum = 0;$i = 0;  while(isset($key{$i})) $knum +=ord($key{$i++});  $mdKey = substr(md5(md5(md5($key.$ch1).$ch2.$ikey).$ch3),$nhnum%8,$knum%8 + 16);  $txt = base64_encode(time().‘_‘.$txt);  $txt = str_replace(array(‘+‘,‘/‘,‘=‘),array(‘-‘,‘_‘,‘.‘),$txt);  $tmp = ‘‘;  $j=0;$k = 0;  $tlen = strlen($txt);  $klen = strlen($mdKey);  for ($i=0; $i<$tlen; $i++) {    $k = $k == $klen ? 0 : $k;    $j = ($nhnum+strpos($chars,$txt{$i})+ord($mdKey{$k++}))%64;    $tmp .= $chars{$j};  }  $tmplen = strlen($tmp);  $tmp = substr_replace($tmp,$ch3,$nh2 % ++$tmplen,0);  $tmp = substr_replace($tmp,$ch2,$nh1 % ++$tmplen,0);  $tmp = substr_replace($tmp,$ch1,$knum % ++$tmplen,0);  return $tmp;}

  解密函数:

/** * 解密函数 * * @param string $txt 需要解密的字符串 * @param string $key 密匙 * @return string 字符串类型的返回结果 */function decrypt($txt, $key = ‘‘, $ttl = 0){  if (empty($txt)) return $txt;  if (empty($key)) $key = md5(MD5_KEY);  $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.";  $ikey ="-x6g6ZWm2G9g_vr0Bo.pOq3kRIxsZ6rm";  $knum = 0;$i = 0;  $tlen = @strlen($txt);  while(isset($key{$i})) $knum +=ord($key{$i++});  $ch1 = @$txt{$knum % $tlen};  $nh1 = strpos($chars,$ch1);  $txt = @substr_replace($txt,‘‘,$knum % $tlen--,1);  $ch2 = @$txt{$nh1 % $tlen};  $nh2 = @strpos($chars,$ch2);  $txt = @substr_replace($txt,‘‘,$nh1 % $tlen--,1);  $ch3 = @$txt{$nh2 % $tlen};  $nh3 = @strpos($chars,$ch3);  $txt = @substr_replace($txt,‘‘,$nh2 % $tlen--,1);  $nhnum = $nh1 + $nh2 + $nh3;  $mdKey = substr(md5(md5(md5($key.$ch1).$ch2.$ikey).$ch3),$nhnum % 8,$knum % 8 + 16);  $tmp = ‘‘;  $j=0; $k = 0;  $tlen = @strlen($txt);  $klen = @strlen($mdKey);  for ($i=0; $i<$tlen; $i++) {    $k = $k == $klen ? 0 : $k;    $j = strpos($chars,$txt{$i})-$nhnum - ord($mdKey{$k++});    while ($j<0) $j+=64;    $tmp .= $chars{$j};  }  $tmp = str_replace(array(‘-‘,‘_‘,‘.‘),array(‘+‘,‘/‘,‘=‘),$tmp);  $tmp = trim(base64_decode($tmp));  if (preg_match("/\d{10}_/s",substr($tmp,0,11))){    if ($ttl > 0 && (time() - substr($tmp,0,11) > $ttl)){      $tmp = null;    }else{      $tmp = substr($tmp,11);    }  }  return $tmp;}

以上所述是小编给大家介绍的PHP利用Cookie设置用户30分钟未操作自动退出功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对站的支持!

您可能感兴趣的文章:

  • 详解cookie验证的php应用的一种SSO解决办法
  • PHP与JavaScript针对Cookie的读写、交互操作方法详解
  • PHP中Cookie的使用详解(简单易懂)
  • php及codeigniter使用session-cookie的方法(详解)
  • PHP如何读取由JavaScript设置的Cookie
  • PHP设置Cookie的HTTPONLY属性方法
  • php cookie用户登录的详解及实例代码
  • php页面跳转session cookie丢失导致不能登录等问题的解决方法
  • php cookie 详解使用实例
  • PHP Cookie学习笔记
  • PHP中cookie知识点学习


  • 上一条:
    PHP实现对文件锁进行加锁、解锁操作的方法
    下一条:
    PHP错误处理函数register_shutdown_function使用示例
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客