laravel设置Cookies不生效怎么解决

laravel设置Cookies不生效怎么解决,第1张

先检查设置的cookie是否有被发送到服务器,然后检查取cookie的方法是否正确。laravel的cookie默认是加密的,如果使用PHP原生的“$_COOKIE”去获取cookie是获取不到的,必须使用“Cookie::get”。在响应里设置response('')->withCookie(cookie('name','laravel',1000))

Cookie::make('test', 'hello, world', 10)

echo Cookie::get('test')如果你按照这种类似的回答来测试Cookie,肯定会发现设置cookie的值永远都是null。多次测试无效下,你都会怀疑自己的Laravel框架是不是有问题!

其实,在Laravel框架中使用Cookie,就不得不提到Response和Request。经常用浏览器调试程序的开发者可能会留意过,在请求地址的Response Headers和Request Headers中,都包含有cookie信息。没错,如果你在Laravel框架中使用Cookie都离不开Response和Request,下面我们就来介绍Cookie的正确添加和获取方法。

Cookie::make()、Cookie::forever()、Cookie::get()的使用方法:

Route::get('cookieset', function()

{

$foreverCookie = Cookie::forever('forever', 'Success')

$tempCookie = Cookie::make('temporary', 'Victory', 5)//参数格式:$name, $value, $minutes

return Response::make()->withCookie($foreverCookie)->withCookie($tempCookie)

})

Route::get('cookietest', function()

{

$forever = Cookie::get('forever')

$temporary = Cookie::get('temporary')

return View::make('cookietest', array('forever' =>$forever, 'temporary' =>$temporary, 'variableTest' =>'works'))

})

//先上一个demo写入cookie

$cookie = \Cookie('cookie_name', 'value', 5)

$data = ['title'=>'hello world']

return \response()

->view('home.hello', $data)

->cookie($cookie)2、Cookie存储数组:

Route::get('cookieset', function()

{

$user_info = array('name'=>'laravel','age'=>12)

$user = Cookie::make('user',$user_info,30)

return Response::make()->withCookie($user)

})

Route::get('cookietest', function()

{

dd(Cookie::get('user'))

})

我这边总结一下,也许以后有人会需要,

其实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'])

大致如此.


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/tougao/11184196.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-14
下一篇 2023-05-14

发表评论

登录后才能评论

评论列表(0条)

保存