CheckSession.php 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\AdminUser;
  4. use Closure;
  5. use Illuminate\Support\Facades\DB;
  6. class CheckSession
  7. {
  8. /**
  9. * Handle an incoming request.
  10. *
  11. * @param \Illuminate\Http\Request $request
  12. * @param \Closure $next
  13. * @return mixed
  14. */
  15. public function handle($request, Closure $next)
  16. {
  17. // if(!env('admin_check',0)){
  18. // exit(0);
  19. // return false;
  20. // }
  21. $ip = $request->ip();
  22. // $white_ip = DB::table('agent.dbo.ip_white_list')->where('ip', $ip)->exists();
  23. // if (!$white_ip) {
  24. // http_response_code(404);
  25. // exit();
  26. // }
  27. // }
  28. if (!$request->session()->has('admin')) {
  29. return redirect('/admin/login_op');
  30. }
  31. $admin = $request->session()->get('admin');
  32. if (!($admin instanceof AdminUser)) {
  33. return redirect('/admin/login_op');
  34. }
  35. \App::setLocale($admin->locale);
  36. // 判断管理员有没有被禁用
  37. $admin_id = $admin->id;
  38. $status = AdminUser::where('id',$admin_id)->value('status');
  39. if ($status == -1) {
  40. return redirect('/admin/login_op');
  41. }
  42. return $next($request);
  43. }
  44. }