CheckSign.php 781 B

1234567891011121314151617181920212223242526272829
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Consts\SysConsts;
  4. use Closure;
  5. class CheckSign
  6. {
  7. /**
  8. * Handle an incoming request.
  9. *
  10. * @param \Illuminate\Http\Request $request
  11. * @param \Closure $next
  12. * @return mixed
  13. */
  14. public function handle($request, Closure $next)
  15. {
  16. $sign = $request->post('sign', '');
  17. $timestamp = $request->post('timestamp', 0);
  18. $key = 'a!A&AFRWT65Nb3NlklezUiqHyQAA@Z8M';
  19. $params = $request->except('_url');
  20. if ($timestamp && time() - $timestamp <= (SysConsts::ONE_HOUR_SECONDS * 10) && $sign == _sign($params, $key)) {
  21. return $next($request);
  22. } else {
  23. return response()->error('QAPP_SIGN_ERROR');
  24. }
  25. }
  26. }