這篇文章為大家帶來了關於Laravel的相關知識,其中主要介紹了Laravel中間件怎麼實現統計用戶在線時長 ,感興趣的朋友下面一起來看一下吧,希望對大家有幫助。
Laravel — 了解用戶上次在線的時間以及總計在線時長
此處以統計後台用戶(admin_users)的在線時長為例;前台使用者的話,只是對應的表不一樣(對應users)。
準備資料庫
此處需要新增兩個字段,分別是上次在線時間和總計在線時長(秒為單位):
<?php use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Schema\Blueprint; use Illuminate\Support\Facades\Schema; class AddSpentToAdminUsersTable extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::table('admin_users', function (Blueprint $table) { $table->unsignedInteger('spent')->default('0')->comment('使用时长')->after('id'); $table->timestamp('onlined_at')->nullable()->comment('最后访问时间')->after('updated_at'); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::table('admin_users', function (Blueprint $table) { // $table->dropColumn(['spent', 'onlined_at']); }); } }
建立中間件
<?php namespace App\Http\Middleware; use Carbon\Carbon; use Closure; use Dcat\Admin\Admin; use Illuminate\Support\Facades\Cache; class CountAdminUserOnlineTime { public function handle($request, Closure $next) { $user = Admin::user(); // 获取当前认证用户 //dd($user); if ($user) { $seenKey = 'auser-last-seen-'; //缓存标识 $lastSeenAt = Cache::get($seenKey . $user->id); // 获取上次访问时间戳 $now = Carbon::now(); if ($lastSeenAt != null) { $duration = $now->diffInSeconds($lastSeenAt); // 计算在线时长(秒数) $user->increment('spent', $duration, ['updated_at' => $user->updated_at, 'onlined_at' => $now]); //updated_at 维持原值 } Cache::put($seenKey . $user->id, $now, Carbon::now()->addMinutes(1)); // 保存当前访问时间戳(并设置缓存过期时间为一分钟) } return $next($request); } }
這裡沒有用使用DB facade 來避免更新使用者表的{更新時間}字段,而用increment 函數的第二個參數來維持updated_at 值不變。
應用中間件
在\app\Http\Kernel.php 中加入一個$routeMiddleware
protected $routeMiddleware = [ //其它 'admin.spent' => \App\Http\Middleware\CountAdminUserOnlineTime::class, //其它 ];
如果你用的是dcat-admin後台框架,可以在config/admin.php 的route 配置裡直接附加middleware:
'middleware' => ['web', 'admin'], // 默认值: 'middleware' => ['web', 'admin', 'admin.spent'], //添加在线时长中间件
其它情況: 在路由定義裡新增:
Route::middleware([/* 其它中间件*/ , 'admin.spent'])->group( function () { //... 需要统计的路由 });
dcat-admin 在概覽頁面展示使用者時長:
//新建一个 AdminUser 模型继承默认的 Administrator <?php namespace App\Models; use Dcat\Admin\Models\Administrator; class AdminUser extends Administrator { } //在线时间表格 use Carbon\Carbon; use Dcat\Admin\Widgets\Callout; use Dcat\Admin\Widgets\Tab; use Dcat\Admin\Widgets\Table; ... public static function tab() { $data = AdminUser::query() ->orderBy('onlined_at', 'DESC') ->get(['name', 'onlined_at', 'spent']) ->toArray(); foreach ($data as &$d) { if (!$d['spent']) { $d['spent'] = '-'; } else { $d['spent'] = formatTime($d['spent']); } if (Carbon::parse($d['onlined_at'])->diffInMinutes() <= 5) { $d['name'] = '<i class="fa fa-circle" style="font-size: 13px;color: #4e9876"></i> ' . $d['name']; } else { $d['name'] = '<i class="fa fa-circle" style="font-size: 13px;color: #7c858e "></i> ' . $d['name']; } } $titles = ['管理员', '最后在线', '总在线时长']; return Tab::make() ->padding(0) ->add('业务信息', Callout::make('后台用户(最近登录)')->success() . Table::make($titles, $data) ); } //公共函数库增加 formatTime /** * 将给定秒数转换为以“x天x时x分钟”形式 * e.g. 123456 => 1天10时17分钟 */ function formatTime($seconds) { $days = floor($seconds / 86400); $hours = floor(($seconds % 86400) / 3600); $minutes = floor(($seconds % 3600) / 60); $result = ""; if ($days > 0) { $result .= "{$days}天"; } if ($hours > 0) { $result .= "{$hours}时"; } if ($minutes > 0) { $result .= "{$minutes}分钟"; } return $result; }
統計結果範例
## 建議學習:「laravel影片教學 # ##
以上是詳解Laravel中間件如何統計使用者線上時長的詳細內容。更多資訊請關注PHP中文網其他相關文章!