标签:String 签发 JWT TOKEN token static user 解析 public
需要的依赖:
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.75</version> </dependency> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.1</version> </dependency>
工具类:
/** * JWT 工具类 * 解决token签发 与 token认证的问题。 */ public class JWTUtil { /** * token签发的有效期 */ public static final int TOKEN_EXPIRE=1000*60*30; /** * token加密算法的盐 */ public static final String TOKEN_KEY="xxxxxx"; /** * 生成一个token */ public static String newToken(UserVO userVO){ //产生token String token= Jwts.builder() .setSubject(userVO.getNickname()) .setIssuedAt(new Date()) .setExpiration(new Date(System.currentTimeMillis()+TOKEN_EXPIRE)) .claim("user", JSONObject.toJSONString(userVO)) .signWith(SignatureAlgorithm.HS256,TOKEN_KEY.getBytes()) .compact(); return token; } /** * 解析token */ public static UserVO checkToken(String token){ Claims body=null; try { body = Jwts.parser().setSigningKey(TOKEN_KEY.getBytes()) .parseClaimsJws(token).getBody(); }catch(Exception e){ return null; } Object userJSONString=body.get("user"); UserVO user=JSONObject.parseObject((String)userJSONString,UserVO.class); return user; } }
标签:String,签发,JWT,TOKEN,token,static,user,解析,public 来源: https://www.cnblogs.com/huangruiwu/p/15546252.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。