php会话id,php会话时间怎么设置

php会话时间的设置方法:首先打开php.ini,并查找Session设置部分;然后通过设置“session.gc_maxlifetime”来设定Session的生存周期即可。

2021032909412127399.jpg

本文操作环境:windows7系统、PHP7.1版,DELL G3电脑

php设置session(过期、失效、有效期)

在php中设置session有很多方面包有给session设置值或直接设置过期、失效和有效期,下面小编来给大家给各位朋友介绍怎么使用。

我们先来看看在php.ini中session怎么设置,打开 php.ini,查找Session设置部分中以下一项,代码如下:

session.save_path =

"N;/path"

session.save_path =

"C:/Temp"

#此处以你自己设定的路径为准

这项设置提供给我们可以给session存放目录进行多级散列,其中“N”表示要设置的目录级数,后面的“/path”表示session文件存放的根目录路径,比如我们设置为下面的格式,代码如下:

session.save_path =

"2;C:/Temp"

上面的设置表示我们把php的session文件进行两级目录存储,每一级目录分别是0-9和a-z共36个字母数字为目录名,这样存放session的目录可以达到36*36个,共1332个文件夹,相信作为单台服务器来说,这是完全够用了,如果说您的系统架构设计为多台服务器共享session数据,可以把目录级增加到3级或者更多。

Session过期时间设定

继续PHP中的Session话题,在PHP中主要通过设置session.gc_maxlifetime来设定Session的生存周期,例如如下代码:

ini_set

(

'session.gc_maxlifetime'

, 3600);

//设置时间

ini_get

(

'session.gc_maxlifetime'

);

//得到ini中设定值

?>

【推荐学习:PHP视频教程】

下面提供一个别人封装好的函数,但是我没有测试过,仅供参考,代码如下:

function

start_session(

$expire

= 0)

{

if

(

$expire

== 0) {

$expire

=

ini_get

(

'session.gc_maxlifetime'

);

}

else

{

ini_set

(

'session.gc_maxlifetime'

,

$expire

);

}

if

(emptyempty(

$_COOKIE

[

'PHPSESSID'

])) {

session_set_cookie_params(

$expire

);

session_start();

}

else

{

session_start();

setcookie(

'PHPSESSID'

, session_id(), time() +

$expire

);

}

}

?>

使用方法:

加入start_session(600);//600秒以后过期。

session永不过期的方法

打开php.ini设置文件,修改三行如下:

1、session.use_cookies

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

2、session.cookie_lifetime

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

3、session.gc_maxlifetime

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

就这样一切ok了,当然你不相信的话就测试一下看看——设置一个session值过个10天半个月的回来看看,如果你的电脑没有断电或者宕机,你仍然可以看见这个sessionid。

当然也可能你没有控制服务器的权限并不能像我一样幸运的可以修改php.ini设置,一切依靠我们自己也是有办法的,当然就必须利用到客户端存储cookie了,吧得到的sessionID存储到客户端的cookie里面,设置这个cookie的值,然后把这个值传递给session_id()这个函数,具体做法如下:<?php

session_start();

// 启动Session

$_SESSION

[

'count'

];

// 注册Session变量Count

isset(

$PHPSESSID

)?session_id(

$PHPSESSID

):

$PHPSESSID

= session_id();

// 如果设置了$PHPSESSID,就将SessionID赋值为$PHPSESSID,否则生成SessionID

$_SESSION

[

'count'

]++;

// 变量count加1

setcookie(

'PHPSESSID'

,

$PHPSESSID

, time()+3156000);

// 储存SessionID到Cookie中

echo

$count

;

// 显示Session变量count的值

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值