[YII2] COOKIE的操作使用

来源:互联网 发布:做淘宝后感想 编辑:程序博客网 时间:2024/05/16 08:30

获取COOKIE过期时间的办法
$expire = time() + 86400; // 设置24小时的有效期
setcookie ("var_name""var_value"$expire); // 设置一个名字为var_name的cookie,并制定了有效期
setcookie ("var_name_expire"$expire$expire); // 再将过期时间设置进cookie以便你能够知道var_name的过期时间




PHPcookie的设置

setcookie('username',$data['username'],time()+3600*24*7);

YII2cookie的设置

$cookies = Yii::$app->response->cookies; $cookies->add(new \yii\web\Cookie([            'name' => 'username',             'value' => $data['username'],              'expire'=>time()+3600*24*7,  ]));

 

PHPcookie的读取

 echo $_COOKIE['username'];

 

YII2cookie的读取

$cookies = Yii::$app->request->cookies;//注意此处是request echo $language = $cookies->get('username');//设置默认值

 

PHPcookie的检测

if(isset($_COOKIE["user"])){ }

 

YII2cookie的检测

$cookies = Yii::$app->request->cookies; if (isset($cookies['user'])){ }if ($cookies->has('user')){ }if (isset($cookies['user'])){ }

PHPcookie的删除

setcookie("user", "", time()-1);unset($_COOKIE['user']);

 

YII2cookie的删除

$cookies = Yii::$app->request->cookies; $cookies->remove('user');

 

其实说白了,框架的存储就是安全性高!

不好读出来的!

 

 

 

 

why we only heard about haves and have-nots, but we did'nt heard about doers and doer-nots. 人生是一种心境,生活是一种艺术,成功是一种心态,幸福是一种感觉,竞争是一种建构,情感是一种容合.学习是一种成长.






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

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

?
1
2
session.save_path = "N;/path"
session.save_path = "C:/Temp"  #此处以你自己设定的路径为准

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

?
1
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的生存周期,例如如下代码:

?
1
2
3
4
<?php
ini_set('session.gc_maxlifetime', 3600); //设置时间
ini_get('session.gc_maxlifetime');//得到ini中设定值
?>

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?php
functionstart_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()这个函数,具体做法如下:

?
1
2
3
4
5
6
7
8
9
<?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的值
?>

以上就是php设置session的具体做法,内容涉及session设置值或直接设置过期、失效和有效期,希望对大家的学习有所帮助。