设为首页 收藏本站
查看: 504|回复: 0

[经验分享] php 严格控制session的过期时间

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-11-23 09:56:50 | 显示全部楼层 |阅读模式
工作过一段时间,相信大家一定也碰到过一个问题:         1.前台用户不知道怎么的就自动掉线了.
        2.后台退出登陆之后所有的前台用户也都掉线了.
        3.我想控制我的用户半个小时自动下线,发现改了配置文件也不好使.


    上述的所有问题都是我近期碰到的,后来通过查询知道:php的session机制由几个参数同时控制,具体是哪些我就不具体写了,分别是一个概率,一个最大过期时间,还有一个session的存储路径.在php.ini中我们可以看到,php的session的默认过期时间位24分钟,也就是说如果我们24分钟没有操作页面,这个session就过期了,当然这是理想状态下.24分钟之后php会出发一个session的回收机制,这个机制用来检测默认存储目录下的session文件的更改时间是否为24分钟之前,如果是那么删除session.当然这也是理想状态下.这就是前面提到的一个概率了,session的回收机制是按概率触发的,也就是说,即使你的session为24分钟之前的文件,如果步触发回收机制你的session依然没有过期.这当然也不是我们想要的了.为了解决这个问题就出现了我前面提到的第三个参数,也就是session的存储路径,如果你没有开启php.ini内部的session.save_path那么session是不会有文件产生的,所以为了能更加有效的控制session我们将其打开并且填写一个路径,或者在文件中用session_save_path(".....")函数来定义这个session的存储的路径.还有一点很重要,那就是成如果session存储在我们自己定义的路径内部,seesion的回收机制是不起作用的.所以只能我们自己来控制session的过期时间了.

    下面是一个我自己根据理解写的一个关于session的过期处理类

        
<?php
        class Session{
                private $savePath;//存储session的路径,必须是绝对路径
                private $time;//存储session的过期时间,单位是秒
                private $sessionName;//session的名字
                private $sessionValue;//session的值

                public function __construct($savePath)
                {
                        //将session存入指定的目录
                        $this->savePath = $savePath;
            //注意:这个一定要写在session_start前面
                        session_save_path($this->savePath);

                        session_start();//开启session
                        if(!is_dir($this->savePath))
                        {
                //默认为最大的权限 0777
                                mkdir($this->savePath) or die('系统错误!');
                        }
                }

                //创建session  一共三个参数,
               // $name->session名字
               // $val->session值
               // $time->过期时间,默认为30分钟
                public function setSession($name,$val,$time=1800)
                {
                        $this->sessionName  = $name;
                        $this->sessionValue  = $val;
                        $this->time       = $time;
                        if(!isset($_SESSION[$this->sessionName]))
                        {
                                if(is_array($this->sessionValue))
                                {
                                        foreach($this->sessionValue as $key=>$val)
                                        {
                                                $_SESSION[$this->sessionName][$key] = $val;
                                        }
                                }
                                else
                                {
                                        $_SESSION[$this->sessionName]['val']   = $this->sessionValue;
                                }
                                $_SESSION[$this->sessionName]["startTime"] = time();
                        }
                        //这时候说明session已经存在,那么我们判断他是否过期,如果过期,删除session
                        else if(isset($_SESSION[$this->sessionName]["startTime"]) && time()-$_SESSION[$this->sessionName]['startTime']>=$this->time)
                        {
                                unset($_SESSION[$this->sessionName]);
                        }
                }
        }
?>

    通过这个类我们可以达到几个目的:

                    1.我们可以明确的控制session的过期时间.

                    2.对应上面的第二个问题,我之前做用户退出登陆的时候通常这样写 session_destroy();或者写成unset($_SESSION);殊不知这样就把所有的session都清除了,所以我们会遇到前面一个用户退出之后,我们自己的session也被删除了.

                    3.用户不会无缘无故的掉线了,因为对我们来说每个步骤现在都是透明的了.



    当然我也有一些疑问:

        1.为什么php会这样设计session机制呢?
        2.服务器到底有没有给我们留下创建文件的权限呢?这个类只是一个小小的测试,至于实际工作中会碰见什么样的问题,我们敬请期待.


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-142469-1-1.html 上篇帖子: php中的empty和isset 下篇帖子: php编译部分错误及解决方法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表