JwtUtil.java 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. package com.sky.ioc.tool;
  2. import com.auth0.jwt.JWT;
  3. import com.auth0.jwt.JWTVerifier;
  4. import com.auth0.jwt.algorithms.Algorithm;
  5. import com.auth0.jwt.interfaces.DecodedJWT;
  6. import com.sky.ioc.entity.domain.system.Users;
  7. import org.springframework.beans.factory.annotation.Value;
  8. import java.time.Instant;
  9. import java.time.temporal.ChronoUnit;
  10. import java.util.Date;
  11. import java.util.UUID;
  12. public class JwtUtil {
  13. @Value("${sky.security.key}")
  14. private static final String secretKey = "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9";
  15. /**
  16. * 生成token
  17. *
  18. * @param users
  19. * @return
  20. */
  21. public static String genJwtToken(Users users) {
  22. String token = JWT.create().withJWTId(UUID.randomUUID().toString()).withAudience("user").withIssuer("sky-ioc-server").withIssuedAt(new Date()).withSubject(users.getUserName()).withClaim("userID", users.getId()).withExpiresAt(Instant.now().plus(16, ChronoUnit.HOURS)).sign(Algorithm.HMAC256(secretKey));
  23. return token;
  24. }
  25. /**
  26. * 解析JWT字符串
  27. *
  28. * @param token
  29. * @return 用户名
  30. */
  31. public static String parseJWT(String token) {
  32. JWTVerifier build = JWT.require(Algorithm.HMAC256(secretKey)).build();
  33. DecodedJWT verify = build.verify(token);
  34. String username = verify.getSubject();
  35. return username;
  36. }
  37. }