authJWT.php 1000 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Http\Appadapter\PartySign;
  4. use Closure;
  5. use \App\Http\Models;
  6. class authJWT
  7. {
  8. /**
  9. * Handle an incoming request.
  10. *
  11. * @param \Illuminate\Http\Request $request
  12. * @param \Closure $next
  13. * @return mixed
  14. */
  15. public function handle($request, Closure $next)
  16. {
  17. try {
  18. $data = $request->input();
  19. if(empty($data['key'])){
  20. return toJson(-30001);
  21. }
  22. $secret = $this->getToken($data['key']);
  23. $partySign = new PartySign($secret);
  24. if(!$partySign->checkSignature($data)) {
  25. return toJson(-30001);
  26. }
  27. } catch (Exception $e) {
  28. return toJson(-30001);
  29. }
  30. return $next($request);
  31. }
  32. private function getToken($key){
  33. $partyModel = new Models\Party;
  34. $partyInfo = $partyModel->where('key', $key)->first();
  35. return $partyInfo['secret'];
  36. }
  37. }