laravel session踩坑

上周做SSO单点登录的时候,选择用session存储本地会话,然后 登录时候记录用户信息没有问题,登出的时候要清空session  问题就来了:

明明已经清空了

session()->flush();
var_dump(session('userInfo'));
//跳转到sso主界面

 

而且打印出为NULL  但是访问另一个路由还是能获取到这个session的值.后来查出了下面的问题:

与$_SESSION不同Laraver中的session是在当次程序执行完毕时保存到文件或其他存储引擎中的,也就是说如果使用了die等强制结束程序的函数将不会自动保存session导致session失效.

这里其实应该称为对session的处理 并不一定就是写操作,因为后面直接跳走了  所以实际上没有清空掉session  所以要加上

return session()->save();

这样就能清空成功了。

这里如果不调用save方法的话 实际上只是存储在startSession中间件指定的对象里,当前进程结束后 进行的操作未保存下来

 

转载于:https://www.cnblogs.com/tudou1223/p/9222790.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值