无法与Laravel 4共享子域名会话

时间:2013-09-24 23:18:43

标签: php session laravel subdomain

我正在尝试在具有许多子域的主机上使用Laravel。只有一个子菜单会运行Laravel的应用程序,但我想通过PHP本地会话分享一些东西(比如当前用户)。

我编辑了Laravel的会话配置以使用子域名,更改了域名值:

'cookie' => 'mydomain_session',
'domain' => '.mydomain.com',

在另一个没有运行Laravel的子域中,我正试图以这种方式访问​​会话:

session_name("mydomain_session");
session_set_cookie_params(0,'/','.mydomain.com',false,true);
session_start();

但它不起作用,如果我尝试回显$ _SESSION变量是空的。

最奇怪的是,如果我尝试回显session_id(),它们在两个子域中都是相同的。

此外,如果我在第三个子域中设置相同的脚本,它与其他非laravel子域共享会话没有问题。

那么我做错了什么?我错过了一些东西,或者Laravel没有以普通的方式管理本机PHP会话?

感谢任何帮助!

3 个答案:

答案 0 :(得分:0)

或Laravel没有以普通方式管理本机PHP会话?

正确。

将其放入routes.php文件的顶部:

Session::put('foo', 'bar');
die(print_r($_SESSION));

你会看到Laravel将会话放入一个多维数组中。

对我来说,“foo”会话包含在$_SESSION['_sf2_attributes']

答案 1 :(得分:0)

您应该切换到JWT(Json Web令牌)。由于他们的设计,他们不会遇到这个问题。

Probaly查看这篇文章了解更多信息: https://auth0.com/blog/2014/01/27/ten-things-you-should-know-about-tokens-and-cookies/

答案 2 :(得分:0)

您可以通过设置

在laravel中跨多个子域共享会话
config(session.domain, '.example.com');

或 在.env文件中

SESSION_DOMAIN='.example.com'