<?php
namespace AppHttpControllers;
use Cookie;
use AppHttpControllersController;
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的门面由IlluminateCookieCookieJar提供,所以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
}







