| 12345678910111213141516171819202122232425262728293031323334353637383940 |
- <?php
- namespace App\Http\Middleware;
- use App\Services\RedisService;
- use Closure;
- use Illuminate\Auth\Middleware\Authenticate as Middleware;
- class ApiLogin 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)
- {
- $response = $next($request);
- $action = app('request')->route()->getAction();
- $controller = class_basename($action['controller']);
- list($controller, $action) = explode('@', $controller);
- $noLoginActs = ['LoginController','TestController','TaskController'];
- $token = $request->all('token');
- $tokenData = RedisService::get("apis:tokens:{$token}");
- $userId = isset($tokenData['id'])? $tokenData['id'] : 0;
- if (!$userId && !in_array($controller, $noLoginActs)) {
- // 在这里可以定制你想要的返回格式, 亦或者是 JSON 编码格式
- return response()->json(message(1004, false, null, 403));
- }
- //如果已登录则执行正常的请求
- return $response;
- }
- }
|