首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么注销后Laravel 5.5会话数据丢失?

注销后,Laravel 5.5会话数据丢失的原因是因为在注销操作中,Laravel会调用Illuminate\Foundation\Auth\AuthenticatesUsers trait中的logout方法,该方法会调用Illuminate\Auth\SessionGuard中的logout方法来执行注销操作。

logout方法中,会调用Illuminate\Session\Store中的flush方法来清空会话数据。这意味着会话中的所有数据都会被删除,包括用户认证信息和其他自定义的会话数据。

这种设计是为了确保用户在注销后,会话数据不会被保留,以增加系统的安全性。因为注销操作通常是用户主动发起的,用户希望在注销后,会话数据被完全清除,以确保下一次登录时不会出现任何残留数据。

然而,如果您希望在注销后保留一些会话数据,可以通过自定义注销方法来实现。您可以创建一个新的控制器方法,覆盖默认的logout方法,并在该方法中手动处理会话数据的清除。例如,您可以使用forget方法来删除指定的会话数据,而不是使用flush方法来清空整个会话。

总结起来,注销后Laravel 5.5会话数据丢失是因为默认的注销操作会调用flush方法来清空整个会话数据。这是为了确保用户在注销后,会话数据被完全清除,以增加系统的安全性。如果您希望在注销后保留一些会话数据,可以通过自定义注销方法来实现。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

10个技巧优化PHP程序Laravel 5框架

注意:此命令要运行在 php artisan config:cache ,因为 optimize 命令是根据配置信息(如:config/app.php 文件的 providers 数组)来生成文件的。...使用 Memcached 来存储会话 每一个 Laravel 的请求,都会产生会话,修改会话的存储方式能有效提高程序效率,会话的配置信息是 config/session.php,建议修改为 Memcached...数据库请求优化 数据关联模型读取时使用 延迟预加载 和 预加载 ; 使用 Laravel Debugbar 或者 Clockwork 留意每一个页面的总数据库请求数量; 这里的篇幅只写到与 Laravel...为数据集书写缓存逻辑 合理的使用 Laravel 提供的缓存层操作,把从数据库里面拿出来的数据集合进行缓存,减少数据库的压力,运行在内存上的专业缓存软件对数据的读取也远远快于数据库。...使用即时编译器 HHVM 和 OpCache 都能轻轻松松的让你的应用程序在不用做任何修改的情况下,直接提高 50% 或者更高的性能,PHPhub 之前做个一个实验,具体请见:使用 OpCache 提升 PHP 5.5

5.3K20

详解将数据Laravel传送到vue的四种方式

在过去的两三年里,我一直在研究同时使用 Vue 和 Laravel 的项目,在每个项目开发的开始阶段,我必须问自己 “我将如何将数据Laravel 传递到 Vue ?”。...直接回显到数据对象或组件属性中 ? 赞成: 简单明了 反对: 必须与嵌入到 Blade 模板中的 Vue 应用程序一起使用 可以说是将数据Laravel 应用程序移动到 Vue 前端的最简单方法。...对于 Laravel 5.5+ 使用 json 指令: 使用自定义组件和 Laravel 自身的 json blade 指令可以让您轻松地将数据移动到道具中。...我们为什么要这样做?这样做有什么作用吗?它使我们通过 api 拉入的路由也可以包含应用程序的常规网络路由通常会使用到的所有会话标量和令牌。...这个方法唯一警告的是,你必须使用 Laravel 和 一个 blade 模板来渲染前端。这样框架可以将必要的会话令牌和变量注入到请求当中。 使用 JWT 认证的 API 调用 ?

8K31

Laravel 模型事件的应用

在日常处理一些用户操作事件时,我们有时候需要记录下来,方便以后查阅,或者大数据统计。...Laravel在模型事件中处理起来很方便:https://laravel-china.org/docs/laravel/5.5/eloquent#events Laravel 的模型事件有两种方式,...ObserverLogServiceProvider中运行 ObserverLogServiceProvider 为需要的模型注册事件(我这挺多的,之后大概长这样) 模型注册事件 然后我们触发一些事件(增删改,表的数据就有了...PermissionRoleEventLog也继承基类LogBaseServer,这里就是根据传入的数组id遍历,然后创建日志 PermissionRoleEventLog 之后应用事件 事件 更优雅的处理登录注销事件...EventServiceProvider中的subscribe属性绑定好处理的类 EventServiceProvider 事件监听类的方法 事件监听类 之后的效果就是这样了: 数据

16910

Restful安全认证及权限的解决方案

需要解决会话共享及跨域请求的问题。  2.JWT  JSON Web Token。 ...,但Token还在时效内的问题,如果Token在Redis中存在,则说明用户已注销;如果Token不存在,则校验通过。 ...但如果用户的手机丢失,则可提供一种方式由用户决定撤销哪个设备的令牌。当然,这就需要服务端记录设备的名称,例如“maryo的iPad”。然后用户可以去申请并撤销获得“maryo的iPad”。...在缓存中不保存Token,而是保存一个计数,每次更换Token时,计数加1,这个计数的值会跟用户ID一起加密保存在新生成的Token中,返回给用户,用户每次访问时携带这个Token。...七、附录  https://www.toptal.com/web/cookie-free-authentication-with-json-web-tokens-an-example-in-laravel-and-angularjs

2.8K50

写在 Laravel 5.5 发布之前

目前我在内部项目中已经在使用 Laravel 5.5,接下来会连续地翻译、撰写相关 Laravel 5.5 版本的文章。 FAQ Q: Laravel 5.5 什么时候发布?...Q: Laravel 5.5 发布之后,5.4 还会继续提供支持吗?...A: Laravel 官方有一个Laravel 发布进程表(Laravel Release process)。 Q: 怎样才能在 Laravel 5.5 发布最快得到通知?...A: Laravel News提供了最新消息发布的实时邮件通知,还提供了每周一期的 Laravel newsletter, 你可以加入邮件订阅,即可在新版本正式发布尽快得到通知。...但是现在已经可以着手准备进行服务器上的 PHP 版本升级了,如果使用了原生 MySQL扩展,在升级到PHP 7.0 之前建议先切换到 pdo-MySQL 或者 MySQLi 来实现 MySQL 数据库连接和查询

1.9K40

Laravel5.2之Model Observer模型观察者

备注:上一篇文章:Laravel5.2之Redis保存页面浏览量,在开发的时候有个逻辑有点在意:那篇文章再用Redis保存浏览量,当浏览量达到设置的次数刷到MySQL里,同时把Redis里该浏览量键抹掉...,还有Post的内容键抹掉,以便下一次请求从MySQL里请求到新的数据并缓存。...开发环境:Laravel5.1+MAMP+PHP7+MySQL5.5 没有Model Observer逻辑 看下最主要的浏览量达到一定量刷到MySQL里的逻辑: /** * 不同用户访问,更新缓存中浏览次数...前缀,因为Cache::remember会自动在每一个key前加上laravel前缀,可以看cache.php中这个字段:'prefix' => 'laravel'...//使用Model Observer注销这句 // Redis::command('DEL', ['laravel:post:cache:'.

1.7K21

laravel5.5 中读写分离需要注意的一个小问题

Laravel5.5Laravel 最新的一个 LTS 版本,发布至今已有些时日,眼看着 5.6 都快出来了,最近终于下手将公司项目从 Laravel5.2 升级到 5.5。...自己直接连上数据库一查,里面明明白白的记录摆在那儿,难道见鬼了不成? 起初以为是 prettus/l5-repository 包的缓存引起的,但关掉它的缓存功能问题依旧。...后来好一阵折腾,直到再一次仔细翻看文档, 才发现 Laravel5.5 数据库读写分离配置的部分额外提到了一个 sticky 项,文档里这部分原文如下: The sticky Option The...所以情况一下就明朗了,在没有启用 sticky 的时候,使用 write 连接写入数据立即读取,读取时使用的是 read 连接,这样就有可能出问题。...对比过早前版本的文档发现,sticky 配置项确实是在 laravel5.5 文档里首次出现。但仅仅是在数据库配置的章节里,版本升级指南中却没有提到。

88730

单点登录原理与简单实现

cookie是浏览器用来存储少量数据的一种机制,数据以”key/value“形式存储,浏览器发送http请求时自动附带cookie信息 tomcat会话机制当然也实现了cookie,访问tomcat服务器时...虽然单系统的登录解决方案很完美,但对于多系统应用群已经不再适用了,为什么呢? 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器与服务器之间维护会话状态。...,令牌校验成功sso-server将发送校验请求的系统注册到sso认证中心(就是存储起来的意思) 令牌与注册系统地址通常存储在key-value数据库(如redis)中,redis可以为key设置有效时间也就是令牌的有效期...redis运行在内存中,速度非常快,正好sso-server不需要持久化任何数据。 令牌与注册系统地址可以用下图描述的结构存储在redis中,可能你会问,为什么要存储这些系统的地址?...sso-client还需将当前会话id与令牌绑定,表示这个会话的登录状态与令牌相关,此关系可以用java的hashmap保存,保存的数据用来处理sso认证中心发来的注销请求 8、注销过程 用户向子系统发送带有

2.6K20

单点登录原理与简单实现

cookie是浏览器用来存储少量数据的一种机制,数据以”key/value“形式存储,浏览器发送http请求时自动附带cookie信息   tomcat会话机制当然也实现了cookie,访问tomcat...虽然单系统的登录解决方案很完美,但对于多系统应用群已经不再适用了,为什么呢?   单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器与服务器之间维护会话状态。...,令牌校验成功sso-server将发送校验请求的系统注册到sso认证中心(就是存储起来的意思)   令牌与注册系统地址通常存储在key-value数据库(如redis)中,redis可以为key设置有效时间也就是令牌的有效期...redis运行在内存中,速度非常快,正好sso-server不需要持久化任何数据。   令牌与注册系统地址可以用下图描述的结构存储在redis中,可能你会问,为什么要存储这些系统的地址?...sso-client还需将当前会话id与令牌绑定,表示这个会话的登录状态与令牌相关,此关系可以用java的hashmap保存,保存的数据用来处理sso认证中心发来的注销请求 8、注销过程   用户向子系统发送带有

1.2K20

单点登录原理与简单实现

cookie是浏览器用来存储少量数据的一种机制,数据以”key/value“形式存储,浏览器发送http请求时自动附带cookie信息 tomcat会话机制当然也实现了cookie,访问tomcat服务器时...虽然单系统的登录解决方案很完美,但对于多系统应用群已经不再适用了,为什么呢? 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器与服务器之间维护会话状态。...redis运行在内存中,速度非常快,正好sso-server不需要持久化任何数据。 令牌与注册系统地址可以用下图描述的结构存储在redis中,可能你会问,为什么要存储这些系统的地址?...7、sso-client校验令牌成功创建局部会话 令牌校验成功,sso-client将当前局部会话标记为“已登录”,修改LoginFilter.java,添加几行 if (verifyResult)...保存,保存的数据用来处理sso认证中心发来的注销请求 8、注销过程 用户向子系统发送带有“logout”参数的请求(注销请求),sso-client拦截器拦截该请求,向sso认证中心发起注销请求 String

1K20

单点登录原理与简单实现 原

cookie是浏览器用来存储少量数据的一种机制,数据以”key/value“形式存储,浏览器发送http请求时自动附带cookie信息  tomcat会话机制当然也实现了cookie,访问tomcat...虽然单系统的登录解决方案很完美,但对于多系统应用群已经不再适用了,为什么呢? 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器与服务器之间维护会话状态。...redis运行在内存中,速度非常快,正好sso-server不需要持久化任何数据。   令牌与注册系统地址可以用下图描述的结构存储在redis中,可能你会问,为什么要存储这些系统的地址?...7、sso-client校验令牌成功创建局部会话   令牌校验成功,sso-client将当前局部会话标记为“已登录”,修改LoginFilter.java,添加几行 if (verifyResult...java的hashmap保存,保存的数据用来处理sso认证中心发来的注销请求 8、注销过程   用户向子系统发送带有“logout”参数的请求(注销请求),sso-client拦截器拦截该请求,向sso

85650

laravel5.5功能尝鲜

6 Request 表单验证 在 Laravel 5.5 的时候,我们可以直接在 Request 对象上面直接写表单验证了,而且在没有提供 token 的情况下,Laravel 5.5 的错误返回也变了...7 make:rule 自定义验证 例如 自定义一个规则叫PhoneValidate php artisan make:rule PhoneValidate 命令执行完成就可以在app/Rules/目录下看到新生成的...10 Markdown 邮件渲染 邮件的 Markdown 写法其实在 Laravel 5.4 的时候就已经支持了,但是对于邮件测试来说,这样的渲染结果其实不是很方便,所以在 Laravel 5.5 的时候...5.5 引进了一个新的路由注册方法:Route::view,这个主要的应用场景就是在我们站点某些页面是不需要数据操作,只是返回一个静态的视图文件的时候就可以直接这样用上。...5.5 引入了新的 API 支持:Api Resource ,这对于我们使用 Laravel 开发 API 应用的使用非常有用,我们可以快速方便的自定义 API 数据的各种格式和返回的字段等。

3K40

单点登录(SSO),从原理到实现

cookie是浏览器用来存储少量数据的一种机制,数据以”key/value“形式存储,浏览器发送http请求时自动附带cookie信息 tomcat会话机制当然也实现了cookie,访问tomcat服务器时...虽然单系统的登录解决方案很完美,但对于多系统应用群已经不再适用了,为什么呢? 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器与服务器之间维护会话状态。...redis运行在内存中,速度非常快,正好sso-server不需要持久化任何数据。 令牌与注册系统地址可以用下图描述的结构存储在redis中,可能你会问,为什么要存储这些系统的地址?...7、sso-client校验令牌成功创建局部会话 令牌校验成功,sso-client将当前局部会话标记为“已登录”,修改LoginFilter.java,添加几行 if (verifyResult)...保存,保存的数据用来处理sso认证中心发来的注销请求 8、注销过程 用户向子系统发送带有“logout”参数的请求(注销请求),sso-client拦截器拦截该请求,向sso认证中心发起注销请求 String

22.4K2513

单点登录原理与实现

cookie是浏览器用来存储少量数据的一种机制,数据以”key/value“形式存储,浏览器发送http请求时自动附带cookie信息 tomcat会话机制当然也实现了cookie,访问tomcat服务器时...,服务器拿到用户名密码去数据库比对,正确的话说明当前持有这个会话的用户是合法用户,应该将这个会话标记为“已授权”或者“已登录”等等之类的状态,既然是会话的状态,自然要保存在会话对象中,tomcat在会话对象中设置登录状态如下...,为什么呢?...redis运行在内存中,速度非常快,正好sso-server不需要持久化任何数据。 令牌与注册系统地址可以用下图描述的结构存储在redis中,可能你会问,为什么要存储这些系统的地址?...("isLogin", true); } sso-client还需将当前会话id与令牌绑定,表示这个会话的登录状态与令牌相关,此关系可以用java的hashmap保存,保存的数据用来处理sso认证中心发来的注销请求

81720

单点登录原理与简单实现

cookie是浏览器用来存储少量数据的一种机制,数据以”key/value“形式存储,浏览器发送http请求时自动附带cookie信息 tomcat会话机制当然也实现了cookie,访问tomcat服务器时...虽然单系统的登录解决方案很完美,但对于多系统应用群已经不再适用了,为什么呢? 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器与服务器之间维护会话状态。...redis运行在内存中,速度非常快,正好sso-server不需要持久化任何数据。 令牌与注册系统地址可以用下图描述的结构存储在redis中,可能你会问,为什么要存储这些系统的地址?...7、sso-client校验令牌成功创建局部会话 令牌校验成功,sso-client将当前局部会话标记为“已登录”,修改LoginFilter.java,添加几行 if (verifyResult)...保存,保存的数据用来处理sso认证中心发来的注销请求 8、注销过程 用户向子系统发送带有“logout”参数的请求(注销请求),sso-client拦截器拦截该请求,向sso认证中心发起注销请求 String

1.2K40

JSON Web Token(JWT)教程:一个基于Laravel和AngularJS的例子

当然,如果我们想避免使用JWE的额外开销,另一个选择是将敏感信息保留在我们的数据库中,并且在需要访问敏感数据时,使用我们的token进行额外的API调用。 为什么需要Web Tokens?...由于HTTP协议是无状态的,因此需要有一种存储用户信息的机制,以及登录每个后续请求对用户进行身份验证的方法。大多数网站使用Cookie来存储用户的会话ID(session ID)。...Laravel后端示例 我们将使用Laravel来处理用户注册,将用户数据保留到数据库,并提供一些需要认证的受限数据,以供Angular应用程序使用。...HomeController处理登录,注册和注销功能。它将用户名和密码数据从登录表单和注册表单传递Auth到向后端发送HTTP请求的服务。...'; }); }]); 仅当用户进行身份验证成功,后端才负责提供受限制的数据

30.5K10

我去!原来单点登录这么简单,这下糗大了!

cookie是浏览器用来存储少量数据的一种机制,数据以”key/value“形式存储,浏览器发送http请求时自动附带cookie信息 tomcat会话机制当然也实现了cookie,访问tomcat服务器时...虽然单系统的登录解决方案很完美,但对于多系统应用群已经不再适用了,为什么呢? 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器与服务器之间维护会话状态。...redis运行在内存中,速度非常快,正好sso-server不需要持久化任何数据。 令牌与注册系统地址可以用下图描述的结构存储在redis中,可能你会问,为什么要存储这些系统的地址?...7、sso-client校验令牌成功创建局部会话 令牌校验成功,sso-client将当前局部会话标记为“已登录”,修改LoginFilter.java,添加几行 if (verifyResult)...保存,保存的数据用来处理sso认证中心发来的注销请求 8、注销过程 用户向子系统发送带有“logout”参数的请求(注销请求),sso-client拦截器拦截该请求,向sso认证中心发起注销请求 String

96810
领券