这篇文章主要介绍了laravel5中cookie的使用,需要的朋友可以参考下
今天在laravel框架中使用cookie的时候,碰到了点问题,自己被迷糊折腾了半多小时.期间研究了cookie的实现类,也在网站找了许多的资料,包括问答。发现并没有解决问题。网上的答案都是互相抄袭,互相转载。其实并没有什么用处。好在最后,我找到了决绝方法。奔着为广大laravel爱好者和开发人员负责的精神,同时也希望大家在使用cookie时少走弯路,在这里把在laravel中cookie的设置和读取方法贡献出来,供大家批评指正。
概述
cookie的添加其实很简单,直接使用cookie::make(),在使用方法前,需要引入cookie的门面use illuminate\support\facades\cookie;,这样就可以完成cookie的设置了(当然不引入直接 \cookie 使用也能通过命名空间自动加载)。
不过,设置后我们如何才能取到cookie值呢?有搜索过相关问题的开发人员肯定知道,网上的答案千篇一律都是:cookie::get(),有的甚至附上了代码:
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的cookie具体咋玩吧
添加cookie
例如,我们需要在控制器中设置一个"hello, laravel"的cookie值,并设置有效期为10分钟。这里推荐使用cookie的队列方法cookie::queue(),因为这样cookie会自动添加到响应:
<?phpnamespace app\http\controllers;use cookie;use app\http\controllers\controller;class dashboardcontroller extends controller{ /** * show the application index. * * @return response */ public function index() { cookie::queue('test', 'hello, laravel', 10);//如果不适用上面的use cookie,这里可以直接调用 \cookie return view('index'); }}
看看response headers中是不是多了一条set-cookie记录。当然,如果你使用的是response,可以直接使用response中的withcookie()方法,将cookie添加到响应中:
public function index(){ //$response = new response(); $cookie = cookie::make('test', 'hello, laravel', 10); return \response::make('index')->withcookie($cookie); //return $response->make('index')->withcookie($cookie);}
要设置一个永不过期的的cookie值,可以使用cookie::forever()方法:
cookie::forever('test', 'hello, laravel');
cookie自身并不提供该方法,由于cookie的门面由\illuminate\cookie\cookiejar提供,所以cookie可以使用该类中的方法。这里附上queue()方法的源码:
/*** queue a cookie to send with the next response.** @param mixed* @return void*/public function queue(){ if (head(func_get_args()) instanceof cookie) { $cookie = head(func_get_args()); } else { $cookie = call_user_func_array([$this, 'make'], func_get_args()); } $this->queued[$cookie->getname()] = $cookie;}
从源码可以得知,queue()方法实际上也是调用的make()方法。
注意:有些水友提出在返回的视图上注入cookie的方法 return view('index')->withcookie($cookie),亲测无效。推荐使用 queue()
获取cookie
在概述里我们提到过,cookie的使用离不开response和request。获取cookie的值有两个层面,一个是服务端,另一个是客户端。如果要服务端获取到cookie的值,就需要从request中获得:
public function index(request $request){ $cookie = $request->cookie('test'); dump($cookie);}
如果想获得所有cookie的值,可以使用不传参数的方法:
public function index(request $request){ $cookies = $request->cookie(); dump($cookies);}
再次访问地址,我们会得到一个所有cookie值的数组,包括我们刚刚设置的test:
array:3 [▼ "xsrf-token" => "cdsxuuyyhjhgddfghjaxpnnsvxlhgtryugj" "laravel_session" => "870a775gthhgef0b9f357edc6r6587878999876556" "test" => "hello, laravel"]
当我们需要在客户端使用的时候,获取cookie的值就不是这样了。首先,我们通过响应withcookie($cookie)传输到客户端的数据并不是一个字符串,而是一个cookie对象:
cookie {#1490 ▼ #name: "test" #value: "hello, laravel" #domain: null #expire: 1493791460 #path: "/" #secure: false #httponly: true}
获取value值,cookie类提供了一个getvalue()的方法来拿取。例如在模板中编辑代码:
<p>{{ $cookie->getvalue() }}</p>
再次刷新页面时,就会得到设置的test的cookie值:
hello, laravel
清除cookie
清除cookie的方法比较简单,原理和设置cookie一样的,只是将过期时间设置成了过去。这里也需要将cookie加入到http的response中,使用make()或者forget()方法均可:
$cookie = cookie::forget('test');return redirect::route('index')->withcookie($cookie);
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注!
相关推荐:
在laravel5.5中利用passport实现auth认证
关于laravel中日期时间处理包carbon的使用
以上就是关于laravel5中cookie的使用的详细内容。