在 Spring Boot 中使用 JWT 进行接口加密解密的方法

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: 【10月更文挑战第18天】

JSON Web Token(JWT)是一种常用的身份验证和授权机制,在 Spring Boot 中可以方便地使用它来实现接口的加密解密。

一、JWT 简介

JWT 由三部分组成:头部(Header)、载荷(Payload)和签名(Signature)。它通过数字签名来保证数据的完整性和真实性。

二、使用步骤

  1. 添加依赖

在项目的 pom.xml 文件中添加 jjwt 等相关依赖。

  1. 生成 JWT

在服务端,根据用户信息生成 JWT。

import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;

public class JwtGenerator {
   

    public static String generateJwt(String userId, String role) {
   
        // 定义 JWT 的有效时间等参数
        long expirationTime = System.currentTimeMillis() + 3600000; 
        // 生成 JWT
        String jwt = Jwts.builder()
              .setSubject(userId)
              .claim("role", role)
              .setExpiration(new Date(expirationTime))
              .signWith(SignatureAlgorithm.HS512, "yourSecretKey")
              .compact();
        return jwt;
    }
}
  1. 解析 JWT

在接口中,接收到 JWT 后进行解析,获取其中的信息。

import io.jsonwebtoken.Jwts;

public class JwtParser {
   

    public static Map<String, Object> parseJwt(String jwt) {
   
        // 解析 JWT
        Map<String, Object> claims = Jwts.parser()
              .setSigningKey("yourSecretKey")
              .parseClaimsJwt(jwt)
              .getBody();
        return claims;
    }
}
  1. 验证 JWT

在接口中,还需要对 JWT 进行验证,确保其合法性。

import io.jsonwebtoken.ExpiredJwtException;

public class JwtValidator {
   

    public static boolean validateJwt(String jwt) {
   
        try {
   
            Jwts.parser().setSigningKey("yourSecretKey").parseClaimsJwt(jwt);
            return true;
        } catch (ExpiredJwtException e) {
   
            // JWT 已过期
            return false;
        } catch (Exception e) {
   
            // 其他异常
            return false;
        }
    }
}

三、注意事项

  1. 密钥管理:确保密钥的安全存储和使用。
  2. JWT 有效期:合理设置 JWT 的有效期,避免过长或过短。
  3. 异常处理:处理好 JWT 验证过程中的各种异常情况。

通过以上步骤,可以在 Spring Boot 中使用 JWT 进行接口的加密解密,实现安全的身份验证和授权。

相关文章
|
26天前
|
XML Java 数据格式
探索Spring之利剑:ApplicationContext接口
本文深入介绍了Spring框架中的核心接口ApplicationContext,解释了其作为应用容器的功能,包括事件发布、国际化支持等,并通过基于XML和注解的配置示例展示了如何使用ApplicationContext管理Bean实例。
52 6
|
13天前
|
Java Spring
【Spring】方法注解@Bean,配置类扫描路径
@Bean方法注解,如何在同一个类下面定义多个Bean对象,配置扫描路径
138 73
|
2月前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
41 1
|
2月前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
37 1
|
2月前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
37 0
|
5月前
|
SQL Java 测试技术
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
|
7月前
|
监控 druid Java
Springboot用JUnit测试接口时报错Failed to determine a suitable driver class configure a DataSource: ‘url‘
Springboot用JUnit测试接口时报错Failed to determine a suitable driver class configure a DataSource: ‘url‘
134 0
|
SQL XML JSON
Spring Boot + vue-element 开发个人博客项目实战教程(九、Postman测试接口)(下)
Spring Boot + vue-element 开发个人博客项目实战教程(九、Postman测试接口)(下)
177 0
|
XML JSON 前端开发
Spring Boot + vue-element 开发个人博客项目实战教程(九、Postman测试接口)(上)
Spring Boot + vue-element 开发个人博客项目实战教程(九、Postman测试接口)(上)
175 0
|
SQL 弹性计算 前端开发
使用aliyunECS服务器+宝塔面板部署springboot后端项目并测试接口
在部署过程中遇到了很多问题,解决起来也是十分繁琐,这里写个笔记记录一下遇到的问题和思路 这里我先打算测试以下后端接口,前端代码还没有进行运行。 还没有购买域名,因为域名需要备案时间要一周所以暂时使用公网ip进行访问。