CheckSession.php 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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. // if($_SERVER['HTTP_HOST']=='api.ouro777.com'){
  22. $ip = $request->ip();
  23. // $white_ip = DB::table('agent.dbo.ip_white_list')->where('ip', $ip)->exists();
  24. // if (!$white_ip) {
  25. // http_response_code(404);
  26. // exit();
  27. // }
  28. // }
  29. if (!$request->session()->has('admin')) {
  30. return redirect('/admin/login_op');
  31. }
  32. $admin = $request->session()->get('admin');
  33. if (!($admin instanceof AdminUser)) {
  34. return redirect('/admin/login_op');
  35. }
  36. \App::setLocale($admin->locale);
  37. // 判断管理员有没有被禁用
  38. $admin_id = $admin->id;
  39. $status = AdminUser::where('id',$admin_id)->value('status');
  40. if ($status == -1) {
  41. return redirect('/admin/login_op');
  42. }
  43. return $next($request);
  44. }
  45. }