AdminApiAuthMiddleware.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Models\SysModels\User;
  4. use App\Servers\Common\PermissionServer;
  5. use App\Servers\Common\RedisDataServer;
  6. use Closure;
  7. class AdminApiAuthMiddleware
  8. {
  9. private $noAuth = [
  10. 'adminApi.login',
  11. 'adminApi.logout',
  12. ];
  13. /**
  14. * Handle an incoming request.
  15. *
  16. * @param \Illuminate\Http\Request $request
  17. * @param \Closure $next
  18. * @return mixed
  19. */
  20. public function handle($request, Closure $next)
  21. {
  22. $clientRoute = request()->route()->getName();//获取当前路由
  23. if (in_array($clientRoute, $this->noAuth)) {//不需要验证的路由
  24. return $next($request);
  25. }
  26. //获取token
  27. $api_token = $request->input('api_token');
  28. if(empty($api_token)) $api_token = $request->header('ApiToken');
  29. if(empty($api_token)){
  30. return response()->json([
  31. 'msg' => '缺少认证信息',
  32. 'code' => 401,
  33. 'data' => []
  34. ]);
  35. }
  36. //获取当前用户
  37. $user = RedisDataServer::creatServer()->getData( 'gw_adminLogin_' . $api_token, 'json');
  38. if(!$user){
  39. //数据库查找当前用户
  40. $user = User::where('api_token', $api_token)->where('is_del', 0)->first();
  41. if($user){
  42. //用户信息缓存
  43. RedisDataServer::creatServer()->setData('gw_adminLogin_' . $api_token, $user, 'json', 300);
  44. }else{
  45. return response()->json([
  46. 'msg' => '身份验证失败',
  47. 'code' => 401,
  48. 'data' => []
  49. ]);
  50. }
  51. }
  52. //状态验证
  53. if($user['status'] == 2){
  54. return response()->json([
  55. 'msg' => '账号已关闭',
  56. 'code' => 402,
  57. 'data' => []
  58. ]);
  59. }
  60. //进行路由验证
  61. $ret = PermissionServer::verifyAuth($user['role_id'], $clientRoute);
  62. if (empty($ret) && $user['id'] != 1) {
  63. return response()->json([
  64. 'msg' => '暂无权限',
  65. 'code' => 402,
  66. 'data' => []
  67. ]);
  68. }
  69. return $next($request);
  70. }
  71. }