WebLogin.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Helpers\Jwt;
  4. use App\Services\RedisService;
  5. use Closure;
  6. use Illuminate\Auth\Middleware\Authenticate as Middleware;
  7. class WebLogin extends Middleware
  8. {
  9. /**
  10. * 执行句柄
  11. * @param \Illuminate\Http\Request $request
  12. * @param Closure $next
  13. * @param mixed ...$guards
  14. * @return mixed
  15. * @throws \Illuminate\Auth\AuthenticationException
  16. * @since 2020/8/31
  17. * @author wesmiler
  18. */
  19. public function handle($request, Closure $next, ...$guards)
  20. {
  21. $action = app('request')->route()->getAction();
  22. $controller = class_basename($action['controller']);
  23. list($controller, $action) = explode('@', $controller);
  24. $noLoginActs = ['LoginController','UploadController','IndexController'];
  25. $token = $request->headers->get('Authorization');
  26. if (strpos($token, 'Bearer ') !== false) {
  27. $token = str_replace("Bearer ", null, $token);
  28. $token = trim($token);
  29. if($token){
  30. // JWT解密token
  31. $jwt = new Jwt('jwt_rship_app');
  32. $userId = $jwt->verifyToken($token);
  33. }else{
  34. return response()->json(message(1035, false, [], 403))->setEncodingOptions(256);
  35. }
  36. } else {
  37. $userId = 0;
  38. }
  39. // 接口验证
  40. $url = $request->get('s');
  41. $url = empty($url)? $request->path() : $url;
  42. $params = $request->except('s');
  43. $sign = $request->header('sign');
  44. if(empty($sign)){
  45. $sign = isset($params['sign'])? $params['sign'] : '';
  46. }
  47. if($action != 'setAvatar'){
  48. $system = isset($params['system']) ? $params['system'] : '';
  49. $system = $system && !is_array($system)? json_decode($system,true) : $system;
  50. $ctime = isset($system['sys_time'])? $system['sys_time'] : 0;
  51. $uuid = isset($system['uuid'])? $system['uuid'] : 0;
  52. $url = '/'.ltrim($url,'/');
  53. $checkSign = getSign("{$url}&{$uuid}&{$ctime}");
  54. if ($ctime < time() - 30 && !in_array($controller, $noLoginActs)) {
  55. return response()->json(message(1012, false, null))->setEncodingOptions(256);
  56. }
  57. if ((empty($sign) || $sign != $checkSign) && !in_array($controller, $noLoginActs)) {
  58. return response()->json(message(1005, false, null))->setEncodingOptions(256);
  59. }
  60. }
  61. // 接口加密验证
  62. $userInfo = RedisService::get("auths:info:{$userId}");
  63. if (($userId<=0 || empty($userInfo))&& !in_array($controller, $noLoginActs)) {
  64. // 在这里可以定制你想要的返回格式, 亦或者是 JSON 编码格式
  65. return response()->json(message(1035, false, [], 403))->setEncodingOptions(256);
  66. }
  67. $request->headers->set('token_uid' , $userId);
  68. //如果已登录则执行正常的请求
  69. return $next($request);
  70. }
  71. }