token的创建与解析

编程入门 行业动态 更新时间:2024-10-07 17:23:06

<a href=https://www.elefans.com/category/jswz/34/1770646.html style=token的创建与解析"/>

token的创建与解析

token的创建
(1)创建maven工程,引入依赖

<!-- 引入jjwt的依赖-->
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId><version>0.6.0</version>
</dependency>

创建类CreateJwtTest,用于生成token

(2)public class CreateJwt {public static void main(String[] args) {//Jwts.builder()生成//Jwts.parser()验证JwtBuilder jwtBuilder =  Jwts.builder().setId("123").setSubject("梦阳")    //用户名.setIssuedAt(new Date())//登录时间.signWith(SignatureAlgorithm.HS256, "my").setExpiration(new Date(new Date().getTime()+60000))//设置过期时间.claim("role","admin"); //自定义属性        //前三个为载荷playload 最后一个为头部 headerSystem.out.println(jwtBuilderpact());}
}

setIssuedAt用于设置签发时间
signWith用于设置签名秘钥
(3)测试运行,输出如下

eyJhbGciOiJIUzI1NiJ9.eyJqdGkiOiI2NjYiLCJzdWIiOiLlsI_pqawiLCJpYXQiOjE1NjMyODU2MTB9.iKtLy0T5ZzvzS2sjgcs5WyuM7cofmnzxzml7wicrTnA
再次运行,会发现每次运行的结果是不一样的,因为我们的载荷中包含了时间

token的解析
我们刚才已经创建了token,在web应用中这个操作是由服务端进行然后发给客户端,客户端在下次向服务端发送请求时需要携带这个token(这就好像是拿着一张门票一样),那服务端接到这个token应该解析出token中的信息(例如用户id),根据这些信息 查询数据库返回相应的结果。

创建ParseJwtTest

//token的解析
//有状态登录  服务器端保存用户信息
//无状态登录  服务器端没有保存用户信息   无状态效率比有状态效率高
public class PraseJwtTest {public static void main(String[] args) {
Claims claims = Jwts.parser().setSigningKey("my").parseClaimsJws("eyJhbGciOiJIUzI1NiJ9.eyJqdGkiOiI2NjYiLCJzdWIiOiLlsI_pqawiLCJpYXQiOjE1NjMyODU2MTB9.iKtLy0T5ZzvzS2sjgcs5WyuM7cofmnzxzml7wicrTnA").getBody();System.out.println("用户id:"+claims.getId());System.out.println("用户名:"+claims.getSubject());System.out.println("用户时间:"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(claims.getIssuedAt()));System.out.println("过期时间:"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(claims.getExpiration()));System.out.println("用户角色:"+claims.get("role"));}
}

试着将token或签名秘钥篡改一下,会发现运行时就会报错,所以解析token也就是验证 token

测试运行,当未过期时可以正常读取,当过期时会引发
io.jsonwebtoken.ExpiredJwtException异常。

更多推荐

token的创建与解析

本文发布于:2024-02-28 01:41:27,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1767372.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:token

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!