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

简介: 【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 进行接口的加密解密,实现安全的身份验证和授权。

相关文章
|
3月前
|
安全 算法 Java
在Spring Boot中应用Jasypt以加密配置信息。
通过以上步骤,可以在Spring Boot应用中有效地利用Jasypt对配置信息进行加密,这样即使配置文件被泄露,其中的敏感信息也不会直接暴露给攻击者。这是一种在不牺牲操作复杂度的情况下提升应用安全性的简便方法。
889 10
|
4月前
|
人工智能 安全 Java
Spring Boot yml 配置敏感信息加密
本文介绍了如何在 Spring Boot 项目中使用 Jasypt 实现配置文件加密,包含添加依赖、配置密钥、生成加密值、在配置中使用加密值及验证步骤,并提供了注意事项,确保敏感信息的安全管理。
1026 1
|
7月前
|
缓存 安全 Java
深入解析HTTP请求方法:Spring Boot实战与最佳实践
这篇博客结合了HTTP规范、Spring Boot实现和实际工程经验,通过代码示例、对比表格和架构图等方式,系统性地讲解了不同HTTP方法的应用场景和最佳实践。
669 5
|
7月前
|
Java Spring 容器
两种Spring Boot 项目启动自动执行方法的实现方式
在Spring Boot项目启动后执行特定代码的实际应用场景中,可通过实现`ApplicationRunner`或`CommandLineRunner`接口完成初始化操作,如系统常量或配置加载。两者均支持通过`@Order`注解控制执行顺序,值越小优先级越高。区别在于参数接收方式:`CommandLineRunner`使用字符串数组,而`ApplicationRunner`采用`ApplicationArguments`对象。注意,`@Order`仅影响Bean执行顺序,不影响加载顺序。
544 2
|
9月前
|
人工智能 自然语言处理 Java
Spring 集成 DeepSeek 的 3大方法(史上最全)
DeepSeek 的 API 接口和 OpenAI 是兼容的。我们可以自定义 http client,按照 OpenAI 的rest 接口格式,去访问 DeepSeek。自定义 Client 集成DeepSeek ,可以通过以下步骤实现。步骤 1:准备工作访问 DeepSeek 的开发者平台,注册并获取 API 密钥。DeepSeek 提供了与 OpenAI 兼容的 API 端点(例如),确保你已获取正确的 API 地址。
Spring 集成 DeepSeek 的 3大方法(史上最全)
|
8月前
|
存储 网络安全 数据库
YashanDB加密方法
YashanDB加密方法
|
9月前
|
存储 缓存 Java
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
1022 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
|
8月前
|
编解码 安全 Java
如何在Spring Boot中实现数据加密
本文介绍了如何在Spring Boot中实现数据加密。首先阐述了数据加密的重要性与应用场景,接着讲解了对称加密和非对称加密的原理及区别。通过添加依赖、配置加密算法、编写加密工具类等步骤,展示了具体实现方法,并在业务代码中应用加密技术保护敏感数据。希望对开发者有所帮助。
599 7
|
Java Spring
Spring(08)——方法注入之替换方法实现
8方法注入之替换方法实现 Spring提供了一种替换方法实现的机制,可以让我们改变某个bean某方法的实现。打个比方我们有一个bean,其中拥有一个add()方法可以用来计算两个整数的和,但这个时候我们想把它的实现逻辑改为如果两个整数的值相同则把它们相乘,否则还是把它们相加,在不改变或者是不能改变源码的情况下我们就可以通过Spring提供的替换方法实现机制来实现这一要求。
950 0
|
4月前
|
Java Spring 容器
SpringBoot自动配置的原理是什么?
Spring Boot自动配置核心在于@EnableAutoConfiguration注解,它通过@Import导入配置选择器,加载META-INF/spring.factories中定义的自动配置类。这些类根据@Conditional系列注解判断是否生效。但Spring Boot 3.0后已弃用spring.factories,改用新格式的.imports文件进行配置。
826 0