Session详解

1、session.gc_maxlifetime 控制 session 有效期 

PHP的session有效期默认是1440秒(24分钟),如果客户端超过24分钟没有刷新,当前session会被回收,失效。

可以修改php.ini的session.gc_maxlifetime来设置session的生命周期,但并不能保证在超过这一时间后session信息立即会删除。因为GC是按机率启动的,可能在某一个长时间内都没有被启动。那么大量的session在超过session.gc_maxlifetime后仍然有效。

session.gc_maxlifetime = 60表示当session文件在60秒后没有被访问,则视为过期session,等待GC回收。

2、session.gc_probability,session.gc_divisor说明

session.gc_probability 与 session.gc_divisor  合起来定义了在每个会话初始化时启动 gc(garbage collection 垃圾回收)进程的概率。此概率用 gc_probability/gc_divisor 计算得来。例如 1/1000 意味着在每个请求中有 0.1% 的概率启动 gc 进程。如果session.gc_probability = 1000,那么GC进程在每次执行session_start()时都会调用,执行收。session.gc_divisor 默认为 1000。 

比如:session.gc_maxlifetime=60,session.gc_divisor=1000,session.gc_probability=1,就表示每一千个用户调用session_start()的时候,就百分百的会执行一次垃圾回收机制,将磁盘上没用的session文件删除。

注意:一般对于一些大型的门户网站,建议将session.gc_divisor调大一点,减少开销

把session.gc_probability/session.gc_divisor的机率提高,会有帮助,但会对性能造成严重影响。

3、举例说明

php.ini配置:

session.gc_maxlifetime = 30

session.gc_divisor         = 1000

session.gc_probability   = 1000

因为gc进程被调用的概率是通过gc_probability/gc_divisor 计算得来的,这里我将session.gc_probability改成1000,而session.gc_divisor 默认情况下也是1000。则gc进程在每次执行session_start()函数的时候都会被调用到。

开启两个会话,如图

过30秒,刷新一个人页面之后,如图:

虽说效果很明显,但是线上环境强烈建议将gc_probability参数调低,使用默认值即可,因为太高会影响性能

4、严格控制session过期方法

(1)永不过期设置,打开php.ini,修改参数

          1、session.use_cookies:

               把这个的值设置为1,利用cookie来传递sessionid

          2、session.cookie_lifetime:

              这个代表SessionID在客户端Cookie储存的时间,默认是0,代表浏览器一关闭SessionID就作废……就                是因为这个所以PHP的 session不能永久使用! 那么我们把它设置为一个我们认为很大的数字吧,                       99999999。

          3、session.gc_maxlifetime:

             这个是Session数据在服务器端储存的时间,如果超过这个时间,那么Session数据就自动删除! 那么我              们也把它设置为99999999。

(2)

ini_set("session.gc_maxlifetime",24 * 3600);

session_start();

$lifetime = 24 * 3600;

setcookie(session_name(), session_id(), time() + $lifetime, '/');

$_SESSION['name'] = 'zhang';

echo '设置成功='.$_SESSION['name'];

(3)

ini_set("session.gc_maxlifetime",24 * 3600);

$lifetime = 24 * 3600;

session_set_cookie_params($lifetime);

session_start();

$_SESSION['num'] = '6055';

echo '设置成功=='.$_SESSION['num'];

(4)使用memcache/redis来保存session,设置过期时间,因为memcache/redis的回收机制不是按机率的,可以确保session过期后失效。

(5)只使用php实现,创建一个session类,在session写入时,把过期时间也写入。读取时,根据过期时间判断是否已过期。

//Session控制类

classSession{

              /**

                * 设置session

                * @param String $name  session name

                * @param Mixed $data  session data

                * @param Int  $expire 超时时间(秒)

               */

                public static function set($name,$data,$expire=600){

                          $session_data=array();

                          $session_data['data'] =$data;

                          $session_data['expire'] = time()+$expire;

                          $_SESSION[$name] =$session_data;

                 }

                 /**

                  * 读取session

                  * @param String $name session name

                  * @return Mixed

                  */

                   public static function get($name){

                          if(isset($_SESSION[$name])){

                                   if($_SESSION[$name]['expire']>time()){

                                               return$_SESSION[$name]['data'];

                                   }else{

                                                self::clear($name);

                                    }

                          }

                          return  false;

                    }

                    /**

                      * 清除session

                      * @param String $name session name

                      */

                      private static function clear($name){

                                unset($_SESSION[$name]);

                      }

            }

demo:

session_start();

$data='123456';

session::set('test',$data, 10);

echosession::get('test');// 未过期,输出

//echosession::get('test');// 已过期

5、清除session(删除服务端与客户端)

session_start();

$_SESSION=array();

if (ini_get("session.use_cookies")) {

            $params = session_get_cookie_params();

            setcookie(session_name(), '', time() - 42000,$params["path"], $params["domain"] $params["secure"], $params["httponly"]);

}

session_destroy();

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容

  • Cookie与Session详解读书笔记,从概念、操作、应用、注意事项以及区别等几方面详细阐述两者的基础知识,它们...
    奋斗live阅读 1,066评论 0 2
  • Web服务器跟踪客户状态通常有四种方法:建立含有跟踪数据的隐藏字段;重写包含额外参数的url;使用持续的cooki...
    exmexm阅读 1,905评论 0 0
  • Session的声明与使用 Session的设置不同于Cookie,必须先启动,在PHP中必须调用session_...
    寻回骄傲阅读 2,927评论 0 18
  • 简单使用 读写session 销毁session 读sessionID 写sessionID 登录超时的应用 在每...
    一只好奇的茂阅读 1,108评论 0 22
  • php.ini设置,上传大文件: post_max_size = 128Mupload_max_filesize ...
    bycall阅读 6,723评论 3 64