Session的配置及使用

简介

由于 HTTP 驱动的应用程序是无状态的,Session 提供了一种在多个请求之间存储有关用户信息的方法,Laravel 通过同一个可读性强的 API 处理各种自带的后台驱动程序。支持诸如比较热门的 Memcached, Redis 和数据库。

配置

Session 的配置文件存储在 config/session.php 文件中。默认情况下,Laravel 为绝大多数应用程序配置的 Session 驱动为 file 默认存到文件中。

session文件的目录:storage\framework\sessions

img

在生产环境中,你可以考虑使用 memcachedredis 驱动,让 Session 的性能更加出色。

Session driver 的配置预设了每个请求存储 Session 数据的位置。Laravel 自带了几个不错而且开箱即用的驱动:

  • file - 将 Session 存储在 storage/framework/sessions 中。
  • cookie - Sessions 被存储在安全加密的 cookie 中。
  • database - Sessions 被存储在关系型数据库中。
  • memcached / redis - Sessions 被存储在基于高速缓存的存储系统中。
  • array - Sessions 存储在 PHP 数组中,但不会被持久化。

Request 获取Session数据

Laravel 中处理 Session 数据有两种主要方法:全局辅助函数 session 和通过一个 Request 实例。首先,我们来看看通过控制器方法类型提示一个 Request 实例来访问 session。控制器方法依赖项会通过 Laravel 服务容器 实现自动注入:

  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use Illuminate\Http\Request;
  5. class UserController extends Controller
  6. {
  7. /**
  8. * 展示给定用户的配置文件。
  9. *
  10. * @param Request $request
  11. * @param int $id
  12. * @return Response
  13. */
  14. public function show(Request $request, $id)
  15. {
  16. $value = $request->session()->get('key');
  17. //
  18. }
  19. }

当你从 Session 获取值时,你还可以传递一个默认值作为 get 方法的第二个参数。如果 Session 中不存在指定的键,便会返回这个默认值。若传递一个闭包作为 get 方法的默认值,并且所请求的键并不存在时,get 方法将执行闭包并返回其结果

  1. $value = $request->session()->get('key', 'default');
  2. $value = $request->session()->get('key', function () {
  3. return 'default';
  4. });

助手函数 Session

你也可以使用全局的 PHP 辅助函数 session 来获取和存储 Session 数据。 使用单个字符串类型的值作为参数调用辅助函数 session 时,它会返回该字该符串对应的 Session 键的值。当使用一个键值对数组作为参数调用辅助函数 session 时,传入的键值将会存储在 Session 中:

  1. Route::get('home', function () {
  2. // 获取 session 中的一条数据...
  3. $value = session('key');
  4. // 指定一个默认值...
  5. $value = session('key', 'default');
  6. // 在 Session 中存储一条数据...
  7. session(['key' => 'value']);
  8. });

门面类 Session

当然也可以像tp一样使用门面类,则可以直接静态方式的调用

控制器头部引用 use Illuminate\Support\Facades\Session;

由于session门面在app.php中已经定义好别名,所以在控制器中引入的时候可以直接use Session

img

  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use Illuminate\Http\Request;
  5. use Session;
  6. class UserController extends Controller
  7. {
  8. public function show()
  9. {
  10. $value = Session::get('key');
  11. }
  12. }

下面的演示均使用门面类的方式进行获取和或者Session

获取所有的 Session 数据

如果你想要获取所有的 Session 数据,可以使用 all 方法:

  1. $data = $request->session()->all();
  2. $data = Request::session()->all();
  3. $data = $session->all();
  4. $data = Session::all();
  5. // 以上这几种方式都可以获取,只是方式不同

判断 Session 中是否存在某个值

要确定 Session 中是否存在某个值,可以使用 has 方法。如果该值存在且不为 null,那么 has 方法会返回 true

  1. if (Session::has('users')) {
  2. }

要确定 Session 中是否存在某个值,即使其值为 null,也可以使用 exists 方法。如果值存在,则 exists 方法返回 true

  1. if (Session::exists('users')) {
  2. //
  3. }

存储Session数据

想要存储数据到 Session,你可以使用 put 方法,或者使用辅助函数 session

  1. // 通过请求实例...
  2. $request->session()->put('key', 'value');
  3. // Session门面类
  4. Session::put('key', 'value');
  5. // 通过全局辅助函数...
  6. session(['key' => 'value']);

在 Session 数组中保存数据

push 方法可以将一个新的值添加到 Session 数组内。例如,假设 user.teams 这个键是包括团队名称的数组,你可以这样将一个新的值加入到数组中:

  1. Session::push('user.teams', 'developers');

获取并删除

pull 方法可以只使用一条语句就从 Session 中获取并删除一条语句:

  1. // 先获取key 然后在删除Session::pull('key', 'default');

删除Session数据

forget 方法会从 Session 中删除指定数据,如果想从 Session 中删除所有数据,可以使用 flush 方法:

  1. // 删除单个值...
  2. Session::>forget('key');
  3. // 删除多个值...
  4. Session::forget(['key1', 'key2']);
  5. // 删除全部
  6. Session::flush();

总结Session使用

  1. Session::all(); // Session中获取所有变量
  2. Session::put('key', 'value'); // Session中存储一个变量**
  3. Session::get('key'); // Session中获取一个变量**
  4. Session::get('key', 'default'); // Session中获取一个变量或返回一个默认值(如果变量不存在)
  5. Session::get('key', function() {
  6. return 'default';
  7. }); // 默认值也可以是一个回调函数返回值
  8. Session::has('users') // 检查一个变量是否在Session中存在**
  9. Session::forget('key'); // Session中删除一个变量**
  10. Session::flush(); // Session中删除所有变量**

补充:session方法也可以在视图中使用,如:{{ Session::get(‘code’)}};

img

Cookie的添加其实很简单,直接使用Cookie::make(),在使用方法前,需要引入Cookie的门面use Illuminate\Support\Facades\Cookie;,这样就可以完成Cookie的设置了

不过,设置后我们如何才能取到Cookie值呢?

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

  1. $foreverCookie = Cookie::forever('forever', 'Success');
  2. $tempCookie = Cookie::make('temporary', 'My name is fantasy', 5);
  3. // 参数格式:$name, $value, $minutes
  4. $forever = Cookie::get('forever');
  5. $temporary = Cookie::get('temporary');
  6. // 当然Cookie也可以存储一个数组
  7. $user_info = array('name'=>'laravel','age'=>12);
  8. $user = Cookie::make('user',$user_info,30);
  9. dd(Cookie::get('user'));

例如,我们需要在控制器中设置一个”Hello, Laravel”的cookie值,并设置有效期为10分钟。这里推荐使用cookie的队列方法Cookie::queue(),因为这样Cookie会自动添加到响应:

  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use Cookie;
  5. class DashboardController extends Controller
  6. {
  7. /**
  8. * Show the application index.
  9. *
  10. * @return Response
  11. */
  12. public function index()
  13. {
  14. //如果不适用上面的use Cookie,这里可以直接调用 \Cookie
  15. // 参数分别为 名称 值 过期时间 一天过期60*60*24
  16. Cookie::queue('test', 'Hello, Laravel', 10)
  17. return view('index');
  18. }
  19. }

看看Response Headers中是不是多了一条set-cookie记录。

要设置一个永不过期的的cookie值,可以使用Cookie::forever()方法:

  1. Cookie::forever('test', 'Hello, Laravel');

Cookie自身并不提供该方法,由于Cookie的门面由\Illuminate\Cookie\CookieJar提供,所以Cookie可以使用该类中的方法。

Cookie的使用离不开Response和Request。获取Cookie的值有两个层面,一个是服务端,另一个是客户端。如果要服务端获取到Cookie的值,就需要从Request中获得:

  1. public function index(Request $request)
  2. {
  3. $cookie = $request->cookie('test');
  4. dump($cookie);
  5. }

如果想获得所有Cookie的值,可以使用不传参数的方法:

  1. public function index(Request $request)
  2. {
  3. $cookies = $request->cookie();
  4. dump($cookies);
  5. }

再次访问地址,我们会得到一个所有cookie值的数组,包括我们刚刚设置的test:

  1. array:3 [▼
  2. "XSRF-TOKEN" => "CDSXUUYYHJHGDDFGHJAxPNNsVxLHGTRYUGJ"
  3. "laravel_session" => "870a775gthhgef0b9f357edc6r6587878999876556"
  4. "test" => "Hello, Laravel"
  5. ]

当我们需要在客户端使用的时候,获取Cookie的值就不是这样了。首先,我们通过响应withCookie($cookie)传输到客户端的数据并不是一个字符串,而是一个cookie对象:

  1. Cookie {#1490
  2. #name: "test"
  3. #value: "Hello, Laravel"
  4. #domain: null
  5. #expire: 1493791460
  6. #path: "/"
  7. #secure: false
  8. #httpOnly: true
  9. }

获取value值,Cookie类提供了一个getValue()的方法来拿取。例如在模板中编辑代码:

  1. <div>{{ $cookie->getValue() }}</div>

再次刷新页面时,就会得到设置的test的cookie值:

  1. Hello, Laravel

清除Cookie的方法比较简单,原理和设置Cookie一样的,只是将过期时间设置成了过去。这里也需要将Cookie加入到HTTP的Response中,使用make()或者forget()方法均可:

  1. Cookie::queue(\Cookie::forget('test'));

无论从事什么行业,只要做好两件事就够了,一个是你的专业、一个是你的人品,专业决定了你的存在,人品决定了你的人脉,剩下的就是坚持,用善良專業和真诚赢取更多的信任

更多相关文章

  1. 13.)PHPWeb开发框架~Laravel接收用户的输入的类
  2. 14.)PHPWeb开发框架~Laravel操作数据库DB类CRUD增删改查的使用
  3. 博客文章如何获取SEO流量
  4. vue父组件与子组件的数据传递
  5. php检测扩展有没有加载成功的几种方法
  6. 仿php中文网
  7. php获取当前的定位城市
  8. php之动态分页
  9. 坚持自己的学习方法不动摇

随机推荐

  1. Android(安卓)opencv库使用遇到的坑
  2. Android(安卓)常用RGB值及名称
  3. Android 进程间通信之LocalSocket
  4. 无法安装android sdk
  5. 与Android有关的三起诉讼事件
  6. Android常见错误之[email&#160;protected
  7. Android Root原理分析及防Root新思路
  8. android拨打电话流程分析
  9. Android获取Apk文件图标信息
  10. Android内核和驱动的详细介绍