Spring Boot中使用JWT进行安全认证

简介: Spring Boot中使用JWT进行安全认证

Spring Boot中使用JWT进行安全认证

1. 引言

在现代的Web应用程序中,安全认证是至关重要的一环。JWT(JSON Web Token)作为一种安全的身份验证解决方案,被广泛应用于Web开发中。本文将介绍如何在Spring Boot中集成JWT实现安全认证,并通过示例展示其基本用法和一些常见的最佳实践。

2. 准备工作

在开始之前,请确保您的Spring Boot项目已经正确配置并运行,并且您已经熟悉基本的Spring Boot开发和安全认证的概念。

3. 添加依赖

首先,在您的Spring Boot项目的pom.xml中添加JWT相关的依赖:

<!-- Maven 依赖 -->
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt</artifactId>
    <version>0.9.1</version>
</dependency>
AI 代码解读

4. 配置JWT

4.1 创建JWT工具类

创建一个工具类来处理JWT的生成、解析和验证:

package cn.juwatech.util;

import io.jsonwebtoken.Claims;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

import java.util.Date;

@Component
public class JwtUtil {
   

    @Value("${jwt.secret}")
    private String secret;

    @Value("${jwt.expiration}")
    private Long expiration;

    public String generateToken(String username) {
   
        Date now = new Date();
        Date expiryDate = new Date(now.getTime() + expiration);

        return Jwts.builder()
                .setSubject(username)
                .setIssuedAt(now)
                .setExpiration(expiryDate)
                .signWith(SignatureAlgorithm.HS512, secret)
                .compact();
    }

    public String getUsernameFromToken(String token) {
   
        Claims claims = Jwts.parser()
                .setSigningKey(secret)
                .parseClaimsJws(token)
                .getBody();

        return claims.getSubject();
    }

    public boolean validateToken(String token) {
   
        try {
   
            Jwts.parser().setSigningKey(secret).parseClaimsJws(token);
            return true;
        } catch (Exception e) {
   
            return false;
        }
    }
}
AI 代码解读

4.2 配置JWT属性

application.propertiesapplication.yml中配置JWT的密钥和过期时间:

jwt.secret=mySecretKey
jwt.expiration=86400000   # 令牌过期时间,单位毫秒,这里设置为1天
AI 代码解读

5. 示例应用

现在,我们来创建一个简单的Spring Boot控制器,演示如何使用JWT进行用户认证和授权:

package cn.juwatech.controller;

import cn.juwatech.util.JwtUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

@RestController
@RequestMapping("/api/auth")
public class AuthController {
   

    @Autowired
    private JwtUtil jwtUtil;

    @PostMapping("/login")
    public String login(@RequestParam String username, @RequestParam String password) {
   
        // 校验用户名密码(略)
        // 如果验证通过,则生成JWT并返回给客户端
        String token = jwtUtil.generateToken(username);
        return token;
    }

    @GetMapping("/user")
    public String getUserInfo(@RequestHeader("Authorization") String token) {
   
        String username = jwtUtil.getUsernameFromToken(token);
        return "当前登录用户:" + username;
    }
}
AI 代码解读

6. 结论

通过本文的介绍,我们学习了如何在Spring Boot中集成JWT进行安全认证。JWT作为一种轻量级且安全的认证机制,能够有效地保护您的应用程序免受未经授权的访问。

目录
打赏
0
0
0
0
74
分享
相关文章
什么是JWT?如何使用Spring Boot Security实现它?
什么是JWT?如何使用Spring Boot Security实现它?
765 5
Spring Boot 3 集成 Spring Security + JWT
本文详细介绍了如何使用Spring Boot 3和Spring Security集成JWT,实现前后端分离的安全认证概述了从入门到引入数据库,再到使用JWT的完整流程。列举了项目中用到的关键依赖,如MyBatis-Plus、Hutool等。简要提及了系统配置表、部门表、字典表等表结构。使用Hutool-jwt工具类进行JWT校验。配置忽略路径、禁用CSRF、添加JWT校验过滤器等。实现登录接口,返回token等信息。
948 13
SpringBoot集成Shiro权限+Jwt认证
本文主要描述如何快速基于SpringBoot 2.5.X版本集成Shiro+JWT框架,让大家快速实现无状态登陆和接口权限认证主体框架,具体业务细节未实现,大家按照实际项目补充。
169 11
|
5月前
|
Spring Boot 应用如何实现 JWT 认证?
Spring Boot 应用如何实现 JWT 认证?
135 8
CC-ADMIN后台简介一个基于 Spring Boot 2.1.3 、SpringBootMybatis plus、JWT、Shiro、Redis、Vue quasar 的前后端分离的后台管理系统
CC-ADMIN后台简介一个基于 Spring Boot 2.1.3 、SpringBootMybatis plus、JWT、Shiro、Redis、Vue quasar 的前后端分离的后台管理系统
125 0
在Spring boot中 使用JWT和过滤器实现登录认证
在Spring boot中 使用JWT和过滤器实现登录认证
385 0
使用Spring Boot和JWT实现用户认证
使用Spring Boot和JWT实现用户认证
springBoot:jwt&redis&文件操作&常见请求错误代码&参数注解 (九)
该文档涵盖JWT(JSON Web Token)的组成、依赖、工具类创建及拦截器配置,并介绍了Redis的依赖配置与文件操作相关功能,包括文件上传、下载、删除及批量删除的方法。同时,文档还列举了常见的HTTP请求错误代码及其含义,并详细解释了@RequestParam与@PathVariable等参数注解的区别与用法。

热门文章

最新文章