php session方案

xiaoxiao2021-02-28  50

1、php.ini session部分      session.auto_start = On  自动初始化session    session.auto_start = Off 不自动初始化session    session.use_cookies      把这个的值设置为1,利用cookie来传递sessionid    session.cookie_lifetime  这个代表SessionID在客户端Cookie储存的时间    session.gc_maxlifetime   这个是Session数据在服务器端储存的时间,如果超过这个时间,那么Session数据就自动删除    session_start()做了哪些初始化工作 2、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级或者更多。 2、session_start()做了哪些初始化工作   (1)读取名为PHPSESSID(如果没有改变默认值)的cookie值,假使为abc123 (2)若读取到PHPSESSID这个COOKIE,创建$_SESSION变量,并从相应的目录中(可以再php.ini中设置  )读取SESS_abc123(默认是这种命名方式)文件,将字符装在入$_SESSION变量中;      若没有读取到         PHPSESSID这个COOKIE,也会创建$_SESSION变量,同时创建一个sess_abc321(名称为随机值)的    session文件,同时将abc321作为PHPSESSID的cookie值返回给浏览器端。 2、PHPsession_id保存在cookie    Session过期时间设定 在PHP中主要通过设置session.gc_maxlifetime来设定Session的生存周期,例如如下代码: <?php  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);   }  }  或者没有控制服务器的权限用程序的方法 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的值  ?>  使用方法: 加入start_session(600);//600秒以后过期。 3、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。   没有控制服务器的权限并不能像我一样幸运的可以修改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的值  4、url  session传递   跟没设置cookie时间一样的,关闭了浏览器就没有了   通过浏览器url传过去,通过参数获取session_id作判断(接下来就是程序问题了)

5、设置session时间

     php.ini session.cookie_lifetime 设置9999999

    session_start();  // 保存一天     $lifeTime = 24 * 3600;     setcookie(session_name(), session_id(), time() + $lifeTime, "/"); 

 其实 Session 还提供了一个函数 session_set_cookie_params(); 来设置 Session 的生存期的,该函数必须在 session_start() 函数调用之前调用:   // 保存一天    $lifeTime = 24 * 3600;    session_set_cookie_params($lifeTime);     session_start();      
转载请注明原文地址: https://www.6miu.com/read-67759.html

最新回复(0)