jwtauth.go 884 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. package my_middleware
  2. import (
  3. "dy-admin/internal/pcmserver/pkg/code"
  4. "dy-admin/pkg/jwt"
  5. "dy-admin/pkg/rescode"
  6. "github.com/gin-gonic/gin"
  7. )
  8. func JWTAuth(j *jwt.JWT) gin.HandlerFunc {
  9. return func(c *gin.Context) {
  10. if j == nil {
  11. rescode.WriteErrResponse(c, code.ErrCodeMap[code.ErrJwtInstanceCode])
  12. c.Abort()
  13. return
  14. }
  15. token := c.Request.Header.Get("Authorization")
  16. if token == "" {
  17. rescode.WriteErrResponse(c, code.ErrCodeMap[code.ErrMissingHeaderCode])
  18. c.Abort()
  19. return
  20. }
  21. claims, err := j.ParseToken(token)
  22. if err != nil {
  23. if err == jwt.TokenExpired {
  24. rescode.WriteErrResponse(c, code.ErrCodeMap[code.ErrTokenExpiredCode])
  25. c.Abort()
  26. return
  27. }
  28. rescode.WriteErrResponse(c, code.ErrCodeMap[code.ErrTokenInvalidCode])
  29. c.Abort()
  30. return
  31. }
  32. c.Set("claims", claims)
  33. c.Set("username", claims.Username)
  34. c.Next()
  35. }
  36. }