java jwt登录_JWT实现登录认证实例

本文介绍了JWT的原理及组成,包括头部、负载和签名。通过Java代码展示了如何在登录成功后签发JWT,以及如何校验JWT进行权限认证。在业务中,JWT用于实现无状态的HTTP请求和安全的用户认证。
摘要由CSDN通过智能技术生成

JWT全称JSON Web Token,是一个紧凑的,自包含的,安全的信息交换协议。JWT有很多方面的应用,例如权限认证,信息交换等。本文将简单介绍JWT登录权限认证的一个实例操作。

JWT组成

JWT由头部(Header),负载(Payload)和签名(Signature)三部分组成。其中头部包含了JWT的声明信息,例如签名所用的算法等。

{

"alg": "HS256",

"typ": "JWT"

}

负载部分是负责信息的承载,在通信过程中,我们将要交换的信息放置于负载部分。

{

"sub": "1234567890",

"name": "John Doe",

"admin": true

}

签名部分是JWT安全的保障,在传输过程中,头部和负载部分会经过Base64编码在网络中明文传输,既然是明文,为了保障信息在传输过程中不被篡改。JWT会对编码之后的头部和负载进行一个消息签名。

Signature = HMACSHA256(header + "." + payload + secret)

经过签名之后的JWT保证了数据不会被劫持并篡改。其中secret极为重要,即使有人劫持了消息,在不知道secret的情况下,无法签名出一个有效的JWT。

JWT的形式

JWT由三部分组成:头部,负载和签名。最终的JWT字串可以呈现出这三部分

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用JWT(JSON Web Tokens)实现用户登录时,可以结合图形验证码来增加安全性。下面是一个使用Java实现的示例代码: 首先,需要添加以下依赖项到你的项目中: ```xml <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt-api</artifactId> <version>0.11.2</version> </dependency> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt-impl</artifactId> <version>0.11.2</version> <scope>runtime</scope> </dependency> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt-jackson</artifactId> <version>0.11.2</version> <scope>runtime</scope> </dependency> ``` 然后,你可以创建一个JWT工具类来处理JWT的生成和验证。以下是一个简单的示例: ```java import io.jsonwebtoken.Claims; import io.jsonwebtoken.Jwts; import io.jsonwebtoken.SignatureAlgorithm; import java.util.Date; public class JwtUtil { private static final String SECRET_KEY = "your_secret_key"; private static final long EXPIRATION_TIME = 86400000; // 24小时 public static String generateToken(String username, String captcha) { Date now = new Date(); Date expiryDate = new Date(now.getTime() + EXPIRATION_TIME); return Jwts.builder() .setSubject(username) .claim("captcha", captcha) .setIssuedAt(now) .setExpiration(expiryDate) .signWith(SignatureAlgorithm.HS512, SECRET_KEY) .compact(); } public static String getUsernameFromToken(String token) { Claims claims = Jwts.parser() .setSigningKey(SECRET_KEY) .parseClaimsJws(token) .getBody(); return claims.getSubject(); } public static String getCaptchaFromToken(String token) { Claims claims = Jwts.parser() .setSigningKey(SECRET_KEY) .parseClaimsJws(token) .getBody(); return (String) claims.get("captcha"); } public static boolean validateToken(String token, String username, String captcha) { String storedUsername = getUsernameFromToken(token); String storedCaptcha = getCaptchaFromToken(token); return storedUsername.equals(username) && storedCaptcha.equals(captcha); } } ``` 接下来,你可以在用户登录时生成JWT,并将其返回给客户端。以下是一个简单的登录示例: ```java import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.println("请输入用户名:"); String username = scanner.nextLine(); System.out.println("请输入图形验证码:"); String captcha = scanner.nextLine(); // 验证图形验证码的逻辑 String token = JwtUtil.generateToken(username, captcha); System.out.println("登录成功!生成的JWT为:" + token); } } ``` 在这个示例中,你需要根据你的具体业务逻辑来实现图形验证码的验证过程。 最后,当客户端发起请求时,你可以使用JWT工具类来验证用户的身份和权限。以下是一个简单的示例: ```java import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.println("请输入JWT:"); String token = scanner.nextLine(); System.out.println("请输入用户名:"); String username = scanner.nextLine(); System.out.println("请输入图形验证码:"); String captcha = scanner.nextLine(); boolean isValid = JwtUtil.validateToken(token, username, captcha); if (isValid) { System.out.println("JWT验证通过!"); } else { System.out.println("JWT验证失败!"); } } } ``` 这只是一个简单的示例,你可以根据你的具体需求进行修改和扩展。记得将`your_secret_key`替换为你自己的密钥来保证安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值