1.php session 有效期
PHP的session有效期默认是1440秒(24分钟),如果客户端超过24分钟没有刷新,当前session会被回收,失效。
当用户关闭浏览器,会话结束,session也会失效。
可以修改php.ini的session.gc_maxlifetime来设置session的生命周期,但并不能保证在超过这一时间后session信息立即会删除。因为GC是按机率启动的,可能在某一个长时间内都没有被启动。那么大量的session在超过session.gc_maxlifetime后仍然有效。
2.session.gc_maxlifetime,session.gc_probability,session.gc_divisor说明
session.gc_maxlifetime = 30 表示当session文件在30秒后没有被访问,则视为过期session,等待GC回收。
GC进程调用的概率是通过session.gc_probability/session.gc_divisor计算得来的,而session.gc_divisor默认是1000,
如果session.gc_probability = 1000,那么GC进程在每次执行session_start()时都会调用,执行回收。
把session.gc_probability/session.gc_divisor的机率提高,会有帮助,但会对性能造成严重影响。
3.严格控制session过期方法
1.使用memcache/Redis来保存session,设置过期时间,因为memcache/redis的回收机制不是按机率的,可以确保session过期后失效。
2.只使用php实现,创建一个session类,在session写入时,把过期时间也写入。读取时,根据过期时间判断是否已过期。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
<?php /** * Session控制类 */ class Session{ /** * 设置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:
1
2
3
4
5
6
7
8
|
<?php session_start(); $data = '123456' ; session::set( 'test' , $data , 10); echo session::get( 'test' ); // 未过期,输出 sleep(10); echo session::get( 'test' ); // 已过期 ?> |
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持服务器之家!
原文链接:http://blog.csdn.net/fdipzone/article/details/48816891