Yii2 session操作解析

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_36172443/article/details/79959203

在yii中session是默认在配置文件中开启的

     'session' => [
            // this is the name of the session cookie used for login on the frontend
            'name' => 'advanced-frontend',
        ],

这里session是用来用户登录的验证的。

在控制器中我们也可以对session进行各种操作

 $session = Yii::$app->session; //首先我们先要通过我们的全局应用主体去火的session这个应用组件

        if($session->isActive)
        {//如果session打开就输出下面的话
            echo "Session is active";
        }else{
               $session->open();//打开操作,默认是打开的
        }
         $session->set('user','张三');//设置session
        $session->getSavePath();//获取session的存储路径
       var_dump($session->hasSessionId) ;//是否发送了sessionID
       var_dump($session->id);//当前回话的id
           $session->remove('__flash');//删除操作
        $session->close();//关闭Seesion

注意了,当我们打开session时 有一个__flash的session名称,这是用来存储临时session文件用的

举个例子

比如有一个博客,你做如下操作:

1、新增一篇博客,写好了然后发布
2、跳转到博客列表页或者博客首页,并且显示“发布成功”
3、刷新这个页面或者下次再进入这个页面就不会显示“发布成功”了

这个临时的状态就用flash,用了一次就销毁。

我们再来看一看session组件的源码

class Session extends Component implements \IteratorAggregate, \ArrayAccess, \Countable

实现了ArrayAccess这个接口

只要实现了ArrayAccess接口的类都可以用数组来储存数据
所以我们上面的session创建还可以用以下方法来创建

$session['user']='张三'unset($session['user']);
阅读更多

没有更多推荐了,返回首页