如何共享laravel的session跟cookie
发布网友
发布时间:2022-04-06 06:04
我来回答
共2个回答
懂视网
时间:2022-04-06 10:26
如何才能正确删除 Laravel 应用的 Cookie?
其实这里有一个小坑:我们在删除 Laravel Cookie 的时候,一定要注意返回 Cookie 的删除结果!
$cookie = Cookie::forget('refreshToken');// 这里我们返回的时候要使用 withCookie !return response('view')->withCookie($cookie);
以上解决方案适合在删除 Cookie 后返回视图的应用场景中。
然而,如果我们的请求是 API 请求,并且返回的是 JSON 数据呢,比如:
Cookie::forget('refreshToken');return ['status' => true];
这个时候我们怎么删除 Cookie ?这种1情况下即使我们使用 withCookie 也是没用的!
所以针对这样的应用场景,最终的解决方案是这样的:
Cookie::queue(Cookie::forget('refreshToken'));return ['status' => true];
使用 Cookie::queue 来达到目的。
这样就能正确删除 Laravel Cookie 的值了。
热心网友
时间:2022-04-06 07:34
我这边总结一下,也许以后有人会需要,
其实Laravel的session并不是用PHP自带的session管理器。而是完完全全自己实现了一个。
注意是完完全全自己实现的,并不是传统意义上用session_set_save_handler自定义的session处理器。
所以解决 和另一个ThinkPHP项目的session共用 的问题就很简单了~
在Laravel中启动PHP自带的session就好了,也就是session_start。
这是他们的代码注释 "Note that the Laravel sessions do not make use of PHP "native" sessions in any way since they are crappy."
请记住Laravel在任何地方都没有用到PHP“原生”的session,因为它很蹩脚。
好吧,我现在只要启动蹩脚的session就好了。
by kankana
以上是如何从laravel访问其他程序的session.
以下,则是如何从外部访问laravel的session (file).
当laravel的session driver设置为file, 这些session files都是以json形式存放在app/storage/sessions里面.
关键是,如何找到对应的session文件?
这个文件名是以加密形式存储在cookie的laravel_session里.
如何解密laravel_session获取这个文件名?
1, 首先安装这个库:
https://github.com/illuminate/encryption
2, 获取加密key
位于app/config/app.php 的 key
3,
$encrypter = new Illuminate\Encryption\Encrypter($key);
$session_filename = $encrypter->decrypt($_COOKIE['laravel_session']);
大致如此.