wesmiler 1 tydzień temu
rodzic
commit
cf870737df

+ 2 - 2
app/Http/Controllers/Api/webApp.php

@@ -61,8 +61,8 @@ class webApp extends BaseController
         // 初始化分页参数
         $this->initConfig();
 
-        // 登录检测中间件
-//        $this->middleware('web.login');
+        // 用户信息检测中间件
+        $this->middleware('web.auth');
 
 
         // 初始化登录信息

+ 3 - 3
app/Http/Kernel.php

@@ -66,9 +66,9 @@ class Kernel extends HttpKernel
         'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
         // 后台
         'user.login' => \App\Http\Middleware\UserLogin::class,
-        // app端
+        // web端
+        'web.auth' => \App\Http\Middleware\WebAuth::class,
+        // web端
         'web.login' => \App\Http\Middleware\WebLogin::class,
-        // 司机端
-        'driver.login' => \App\Http\Middleware\DriverLogin::class,
     ];
 }

+ 49 - 0
app/Http/Middleware/WebAuth.php

@@ -0,0 +1,49 @@
+<?php
+
+
+namespace App\Http\Middleware;
+
+use App\Helpers\Jwt;
+use App\Services\JwtService;
+use App\Services\RedisService;
+use Closure;
+use Illuminate\Auth\Middleware\Authenticate as Middleware;
+
+class WebAuth extends Middleware
+{
+    /**
+     * 执行句柄
+     * @param \Illuminate\Http\Request $request
+     * @param Closure $next
+     * @param mixed ...$guards
+     * @return mixed
+     * @throws \Illuminate\Auth\AuthenticationException
+     * @since 2020/8/31
+     * @author wesmiler
+     */
+    public function handle($request, Closure $next, ...$guards)
+    {
+        $action = app('request')->route()->getAction();
+        $controller = class_basename($action['controller']);
+        list($controller, $action) = explode('@', $controller);
+        $noLoginActs = ['LoginController','UploadController','IndexController'];
+        $token = $request->headers->get('Authorization');
+        if (strpos($token, 'Bearer ') !== false) {
+            $token = str_replace("Bearer ", null, $token);
+            $token = trim($token);
+            if($token){
+                // JWT解密token
+                $userId = JwtService::make()->verifyToken($token);
+
+            }else{
+                return response()->json(message(1035, false, [], 403))->setEncodingOptions(256);
+            }
+        } else {
+            $userId = 0;
+        }
+
+        $request->headers->set('token_uid' , $userId);
+        //如果已登录则执行正常的请求
+        return $next($request);
+    }
+}