| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- <?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)
- {
- $userId = 0;
- $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 {
- $userId = 0;
- }
- var_dump($userId.'++');
- $request->headers->set('token_uid' , $userId);
- //如果已登录则执行正常的请求
- return $next($request);
- }
- }
|