首页 > 代码库 > session
session
session_start()是session机制的开始,它有一定概率开启垃圾回收,因为session是存放在文件中,PHP自身的垃圾回收 是无效的,SESSION的回收是要删文件的,这个概率是根据php.ini的配置决定的。session会判断当前是否 有$_COOKIE[session_name()];session_name()返回保存session_id的COOKIE键值,这个值可以从 php.ini找到:
1 |
session.name = PHPSESSID //默认值 |
session.use_cookies:默认值为"1",代表SessionID使用Cookie来传递,反之就是用Query_String来传递。
Session.name:这个就是SessionID储存的变量名称,可能是Cookie来传递,也可能是Query_String来传递,默认值是"PHPSESSID"
Session.cookie_lifetime:这个代表SessionID在客户端Cookie储存的时间,默认值是“0”,代表浏览器一关闭,SessionID就作废,就是因为这个原因,所以Session不能永久使用。
Session.gc_maxlifetime:这个是Session数据在服务器端储存的时间,如果超过这个时间,那么Session数据就自动删除。
session_name()
session_name() 存取目前 session 名称。
语法: string session_name(string [name]);
本函数可取得或者重新配置目前 Session 的名称。若无参数 name 则表示单单获取目前 Session 名称,加上参数则表示将 Session 名称设为参数 name。
如果建立时是这样seesion_register("test");那么就可以用seesion_name("test")来找到这。session_id()这个函数是用来为会话进行编号就好像PHP数组一样支持字符和数字标识。
1 |
<?php |
2 |
3 |
/* set the session name to NowaMagic */ |
4 |
$str = "NowaMagic" ; |
5 |
session_name( $str ); |
6 |
7 |
echo session_name(); |
8 |
9 |
?> |
session_name() 与 session_id() 的区别
我们先自己运行一次程序,看看输出结果:
1 |
<?php |
2 |
session_start(); |
3 |
echo session_name(). ‘=‘ .session_id(); |
4 |
?> |
运行结果:
1 |
PHPSESSID=4d8d3ep8cakmvto6hvut3mphf4 |
现在可以明确了:
session_name() 默认为 "PHPSESSID"
而 session_id() 是 一次HTTP 请求,服务器得到的 $_POST[‘PHPSESSID‘] 或者 $_GET[‘PHPSESSID‘] 或者 $_COOKIE[‘PHPSESSID‘]
如果你在 session_start() 前调用了 session_name(‘SID‘); 那么正常情况下(客户端支持Cookie时), 会给客户端发送 Set-Cookie: SID=(session_id 的值);
小结
一句话:默认值是PHPSESSID,你可以用session_name()修改。
session