1,引入依赖
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt</artifactId>
<version>0.9.1</version>
</dependency>
2,编写工具类
import io.jsonwebtoken.Claims;
import io.jsonwebtoken.JwtBuilder;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import java.util.Date;
import java.util.Map;
/**
* jwt工具类
*
* @author LXX
*/
public class JwtUtils {
public static final String SUBJECT = "LiXunXun";
/**
* 过期时间,毫秒,一天
*/
public static final long EXPIRE = 1000 * 60 * 60 * 24;
/**
* 密钥
*/
public static final String APPSECRET = "LiXunXun";
/**
* 生成jwt
*
* @param map 需要生成的token的对象
* @return 生成的token
*/
public static String geneJsonWebToken(Map<String, Object> map) {
if (map == null || map.isEmpty()) {
return null;
}
JwtBuilder jwtBuilder = Jwts.builder().setSubject(SUBJECT);
for (Map.Entry<String, Object> entry : map.entrySet()) {
jwtBuilder.claim(entry.getKey(), entry.getValue());
}
return jwtBuilder.setIssuedAt(new Date())
.setExpiration(new Date(System.currentTimeMillis() + EXPIRE))
.signWith(SignatureAlgorithm.HS256, APPSECRET).compact();
}
/**
* 校验token
*
* @param token jwt生成的token
* @return 返回对象结果集(map类型)
*/
public static Claims checkJwt(String token) {
try {
return Jwts.parser().setSigningKey(APPSECRET).
parseClaimsJws(token).getBody();
} catch (Exception ignored) {
}
return null;
}
/*public static void main(String[] args) {
Map<String, Object> map = new HashMap<>(2);
map.put("id", 123);
map.put("name", "張三");
map.put("username", "admin");
String s = geneJsonWebToken(map);
System.err.println(s);
Claims claims = checkJwt(s);
assert claims != null;
Integer id = (Integer) claims.get("id");
String name = (String) claims.get("name");
System.err.println(id);
System.err.println(name);
SnowflakeUtils.genId();
}*/
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/72564.html