当前位置: 首页 > article >正文

从登录到鉴权:一个前后端分离项目的完整JWT非对称加密配置指南(Vue3 + Spring Boot)

从登录到鉴权一个前后端分离项目的完整JWT非对称加密配置指南Vue3 Spring Boot在现代Web应用开发中前后端分离架构已成为主流选择。这种架构下如何安全高效地处理用户认证与授权成为一个关键问题。本文将带你从零开始构建一个基于JWT非对称加密的完整认证流程涵盖Vue3前端与Spring Boot后端的协同实现。1. 为什么选择JWT非对称加密传统的会话认证方式如Session-Cookie在分布式系统中面临诸多挑战。JWTJSON Web Token作为一种无状态的认证机制特别适合前后端分离和微服务架构。而非对称加密方案相比对称加密如HS256算法提供了更高的安全性保障。核心优势对比特性对称加密 (HS256)非对称加密 (RS256)密钥管理难度高需共享密钥低仅分发公钥安全性一般高适用场景单一服务分布式系统密钥泄露风险全局失效仅私钥需保护提示在微服务架构中非对称加密允许认证服务持有私钥签发Token而其他服务只需公钥即可验证避免了密钥分发难题。2. 后端实现Spring Boot中的JWT签发与验证2.1 密钥对生成与管理首先我们需要生成RSA密钥对。推荐使用OpenSSL工具生成而非在代码中动态生成# 生成2048位的私钥 openssl genpkey -algorithm RSA -out private_key.pem -pkeyopt rsa_keygen_bits:2048 # 从私钥导出公钥 openssl rsa -pubout -in private_key.pem -out public_key.pem在Spring Boot中我们可以通过Value注入密钥Value(${jwt.private-key}) private String privateKeyStr; Value(${jwt.public-key}) private String publicKeyStr; private PrivateKey getPrivateKey() { try { byte[] keyBytes Base64.getDecoder().decode(privateKeyStr); PKCS8EncodedKeySpec spec new PKCS8EncodedKeySpec(keyBytes); return KeyFactory.getInstance(RSA).generatePrivate(spec); } catch (Exception e) { throw new RuntimeException(Failed to load private key, e); } }2.2 JWT工具类实现创建一个完整的JWT工具类包含签发、验证和解析功能public class JwtUtils { private static final long EXPIRATION_TIME 3600000; // 1小时 public static String generateToken(String username, ListString roles) { return Jwts.builder() .setSubject(username) .claim(roles, roles) .setIssuedAt(new Date()) .setExpiration(new Date(System.currentTimeMillis() EXPIRATION_TIME)) .signWith(getPrivateKey(), SignatureAlgorithm.RS256) .compact(); } public static boolean validateToken(String token) { try { Jwts.parserBuilder() .setSigningKey(getPublicKey()) .build() .parseClaimsJws(token); return true; } catch (Exception e) { log.error(JWT validation error: {}, e.getMessage()); return false; } } public static String getUsernameFromToken(String token) { return Jwts.parserBuilder() .setSigningKey(getPublicKey()) .build() .parseClaimsJws(token) .getBody() .getSubject(); } }2.3 Spring Security集成配置Spring Security使用JWT进行认证Configuration EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { Override protected void configure(HttpSecurity http) throws Exception { http.csrf().disable() .authorizeRequests() .antMatchers(/api/auth/**).permitAll() .anyRequest().authenticated() .and() .addFilter(new JwtAuthenticationFilter(authenticationManager())) .addFilter(new JwtAuthorizationFilter(authenticationManager())) .sessionManagement() .sessionCreationPolicy(SessionCreationPolicy.STATELESS); } }3. 前端实现Vue3中的JWT管理与请求拦截3.1 登录流程与Token存储在Vue3中我们使用axios处理登录请求并安全存储Token// auth.js import axios from axios; import { ref } from vue; const token ref(localStorage.getItem(jwt)); export function useAuth() { const login async (username, password) { try { const response await axios.post(/api/auth/login, { username, password }); token.value response.data.token; localStorage.setItem(jwt, token.value); return true; } catch (error) { console.error(Login failed:, error); return false; } }; return { token, login }; }3.2 Axios请求拦截器配置设置请求拦截器自动附加JWT并处理401未授权响应// http.js import axios from axios; const api axios.create({ baseURL: import.meta.env.VITE_API_BASE_URL }); api.interceptors.request.use(config { const token localStorage.getItem(jwt); if (token) { config.headers.Authorization Bearer ${token}; } return config; }); api.interceptors.response.use( response response, error { if (error.response?.status 401) { // 处理Token过期或无效情况 localStorage.removeItem(jwt); window.location.href /login; } return Promise.reject(error); } ); export default api;4. 分布式系统中的公钥分发机制在微服务架构中我们需要解决公钥的分发问题。以下是几种常见方案方案对比表方案实现复杂度实时性安全性适用场景配置文件分发低低中小型系统配置中心中高高中型分布式系统API端点动态获取高高高大型微服务架构服务网格集成高高高Kubernetes环境推荐实现一个公钥端点RestController RequestMapping(/api/auth) public class AuthController { GetMapping(/public-key) public String getPublicKey() { return publicKeyStr; } }前端可以在初始化时获取公钥虽然前端验证JWT不是必须的但某些场景可能有用// app初始化时 const publicKey await api.get(/api/auth/public-key);5. 高级安全实践与性能优化5.1 安全增强措施Token刷新机制实现短效access token和长效refresh token组合Token撤销列表针对重要操作实现即时撤销能力密钥轮换策略定期更换密钥对降低风险// 刷新Token示例 public String refreshToken(String oldToken) { if (!validateToken(oldToken)) { throw new SecurityException(Invalid token); } String username getUsernameFromToken(oldToken); return generateToken(username); }5.2 性能优化技巧公钥缓存各服务缓存公钥避免每次验证都读取配置验证结果缓存对相同Token的重复验证可缓存结果异步验证高并发场景可使用异步验证机制// 使用Caffeine缓存验证结果 private final CacheString, Boolean tokenValidationCache Caffeine.newBuilder() .expireAfterWrite(5, TimeUnit.MINUTES) .maximumSize(1000) .build(); public boolean validateTokenWithCache(String token) { return tokenValidationCache.get(token, t - { boolean isValid validateToken(t); if (!isValid) { throw new RuntimeException(Invalid token); } return true; }); }在实际项目中我们还需要考虑监控和日志记录。比如记录异常的Token验证尝试监控Token的签发和验证性能指标等。这些措施能帮助我们在享受JWT便利性的同时确保系统的安全性和稳定性。

相关文章:

从登录到鉴权:一个前后端分离项目的完整JWT非对称加密配置指南(Vue3 + Spring Boot)

从登录到鉴权:一个前后端分离项目的完整JWT非对称加密配置指南(Vue3 Spring Boot) 在现代Web应用开发中,前后端分离架构已成为主流选择。这种架构下,如何安全高效地处理用户认证与授权成为一个关键问题。本文将带你从…...

电力电子器件全解析:从二极管到IGBT,手把手教你掌握王兆安教材核心考点

电力电子器件深度解析:从基础原理到高效复习策略 电力电子技术作为现代自动化与能源转换的核心学科,其器件特性与应用的掌握程度直接影响着工程师解决实际问题的能力。对于华南理工大学自动化专业的学生而言,王兆安教授的《电力电子技术》教材…...

OFA视觉蕴含模型部署教程:日志分级输出与推理过程可追溯性设计

OFA视觉蕴含模型部署教程:日志分级输出与推理过程可追溯性设计 1. 镜像简介与核心价值 今天咱们来聊聊一个特别实用的AI模型——OFA视觉蕴含模型。简单来说,它能看懂图片,然后判断你描述的两句话,跟这张图片是什么关系。 想象一…...

s2-pro开源大模型实战:低成本GPU部署语音合成服务完整流程

s2-pro开源大模型实战:低成本GPU部署语音合成服务完整流程 1. 前言:语音合成技术的新选择 语音合成技术正在改变我们与数字世界的交互方式。今天要介绍的s2-pro是Fish Audio开源的一款专业级语音合成模型镜像,它让高质量语音合成服务的部署…...

STM32标准库项目如何用VSCode一键编译下载?详解tasks.json与Makefile的联动配置

STM32标准库项目在VSCode中实现一键编译下载的终极指南 1. 为什么选择VSCode进行STM32开发? 传统嵌入式开发往往依赖于Keil、IAR等商业IDE,但这些工具存在几个明显痛点: 高昂的授权费用:商业IDE的许可证价格让个人开发者和小团队望…...

RimWorld开局定制利器:EdB Prepare Carefully深度应用指南

RimWorld开局定制利器:EdB Prepare Carefully深度应用指南 【免费下载链接】EdBPrepareCarefully EdB Prepare Carefully, a RimWorld mod 项目地址: https://gitcode.com/gh_mirrors/ed/EdBPrepareCarefully 在RimWorld的殖民挑战中,开局配置往往…...

Flux.1-Dev深海幻境作品集:LSTM时序灵感驱动的系列艺术创作

Flux.1-Dev深海幻境作品集:LSTM时序灵感驱动的系列艺术创作 最近在尝试一些AI艺术创作的新玩法,发现了一个特别有意思的组合:用LSTM模型来“读”故事,再用Flux.1-Dev模型来“画”故事。听起来有点抽象?简单说&#xf…...

从4G到RedCap:手把手教你升级老旧工业设备的无线通信模块(附功耗测试数据)

从4G到RedCap:工业设备无线通信模块升级实战指南 在工业物联网快速发展的今天,老旧设备的通信模块升级成为许多工厂面临的现实挑战。传统4G模块虽然稳定可靠,但面对5G时代RedCap技术带来的低功耗、低成本优势,升级改造已成为提升设…...

HFSS建模进阶:如何高效使用布尔运算和局部坐标系(实战案例解析)

HFSS建模进阶:布尔运算与局部坐标系的高效实战指南 在微波器件和天线设计的数字世界里,精确的三维建模往往是成功仿真的第一步。当您已经掌握了HFSS的基础建模操作后,如何将建模效率提升到专业水平?本文将带您深入探索两个常被忽视…...

Ubuntu16.04服务器上从零部署LaneNet车道线检测:Tusimple数据集处理全流程避坑指南

Ubuntu 16.04服务器部署LaneNet车道线检测全流程实战 在自动驾驶和智能交通系统中,车道线检测是一项基础而关键的技术。本文将详细介绍如何在Ubuntu 16.04服务器环境下,从零开始部署LaneNet车道线检测模型,并处理Tusimple数据集的全流程。不同…...

Presto函数实战指南:从基础到高阶应用

1. Presto函数入门:从零开始掌握基础操作 第一次接触Presto函数时,我完全被它丰富的功能震撼到了。记得当时我需要快速分析一个包含数百万条记录的日志表,传统方法需要写复杂的MapReduce作业,而Presto仅用几行SQL函数就搞定了。下…...

重构Sketch图层管理流程:RenameIt效率引擎突破设计协作瓶颈

重构Sketch图层管理流程:RenameIt效率引擎突破设计协作瓶颈 【免费下载链接】RenameIt Keep your Sketch files organized, batch rename layers and artboards. 项目地址: https://gitcode.com/gh_mirrors/re/RenameIt 在现代UI/UX设计工作流中,…...

Zotero Reference插件完全指南:5步实现PDF文献自动化管理

Zotero Reference插件完全指南:5步实现PDF文献自动化管理 【免费下载链接】zotero-reference PDF references add-on for Zotero. 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-reference Zotero Reference是一款革命性的Zotero插件,专门…...

Qwen3-VL-WEBUI新手教程:无需编程,用WebUI轻松玩转多模态AI

Qwen3-VL-WEBUI新手教程:无需编程,用WebUI轻松玩转多模态AI 1. 什么是Qwen3-VL-WEBUI? Qwen3-VL-WEBUI是阿里云推出的一个开箱即用的多模态AI工具,内置了目前Qwen系列中最强大的视觉语言模型Qwen3-VL-4B-Instruct。这个镜像最大…...

告别复杂配置:SDXL 1.0电影级绘图工坊开箱即用体验

告别复杂配置:SDXL 1.0电影级绘图工坊开箱即用体验 1. 为什么选择SDXL 1.0电影级绘图工坊 在AI绘图领域,Stable Diffusion XL(SDXL)1.0代表了当前最先进的文本到图像生成技术。然而,对于大多数非技术背景的创作者来说…...

保姆级教程:在银河麒麟V10桌面版上,用Docker容器化部署SpringBoot + 达梦数据库应用

银河麒麟V10桌面版容器化实战:SpringBoot与达梦数据库的Docker化部署指南 在国产化技术栈日益成熟的今天,将传统应用迁移到容器化环境已成为提升部署效率和系统可移植性的关键路径。银河麒麟V10作为国产操作系统的代表,结合飞腾CPU的硬件生态…...

nlp_gte_sentence-embedding_chinese-large在软件测试用例生成中的应用

nlp_gte_sentence-embedding_chinese-large在软件测试用例生成中的应用 1. 引言 软件测试是确保产品质量的关键环节,但传统的手工编写测试用例方式往往效率低下且容易遗漏重要场景。测试工程师需要反复阅读需求文档,手动提取测试要点,这个过…...

告别无脑抄payload:手把手教你分析RCE-labs靶场PHP源码,自己构造利用链

从源码审计到漏洞利用:深度解析RCE靶场中的PHP代码逻辑 在安全研究领域,真正区分新手与专家的关键能力,往往不是掌握多少现成的攻击载荷(payload),而是能否通过源码审计独立发现漏洞并构造利用链。本文将带…...

vLLM-v0.17.1参数详解:--enforce-eager --disable-custom-all-reduce说明

vLLM-v0.17.1参数详解:--enforce-eager --disable-custom-all-reduce说明 1. vLLM框架简介 vLLM是一个专为大型语言模型(LLM)设计的高性能推理和服务库,以其出色的吞吐量和易用性著称。这个项目最初由加州大学伯克利分校的天空计算实验室开发&#xff…...

轻量级OpenClaw监控:nanobot镜像运行状态仪表盘搭建

轻量级OpenClaw监控:nanobot镜像运行状态仪表盘搭建 1. 为什么需要监控OpenClaw运行状态 上周我在本地部署了基于nanobot镜像的OpenClaw环境,用来对接Qwen3-4B模型实现自动化办公。刚开始使用时一切顺利,直到某天早上发现OpenClaw服务已经停…...

滑模控制消抖新思路:双曲正切函数VS饱和函数效果实测对比

滑模控制消抖技术深度对比:双曲正切函数与饱和函数的实战解析 在智能控制算法的演进历程中,滑模控制(SMC)因其强鲁棒性成为处理系统不确定性和外部干扰的利器。但传统符号函数带来的高频抖振问题,一直是工程师们亟待解…...

Vue项目中el-tabs标签栏的5个高级用法与避坑指南

Vue项目中el-tabs标签栏的5个高级用法与避坑指南 在Vue生态中,Element UI的el-tabs组件是构建标签式界面的首选方案。但很多开发者仅停留在基础使用层面,未能充分发挥其潜力。本文将揭示五个高阶技巧,助你打造更灵活、高效的标签系统。 1. 标…...

Keil5主题配色进阶:不只是好看,更要好用!详解如何区分函数、变量、宏定义的颜色

Keil5主题配色进阶:不只是好看,更要好用!详解如何区分函数、变量、宏定义的颜色 作为一名嵌入式开发者,每天面对Keil5的默认编辑器界面,你是否也感到视觉疲劳?那些单调的配色不仅影响编码心情,更…...

京东云GPU服务器省钱攻略:如何根据业务需求灵活选择计费模式和虚拟化方案

京东云GPU服务器成本优化实战指南:精准匹配业务需求的选型策略 在AI与高性能计算领域,GPU服务器已成为企业技术基础设施的核心组件。然而,面对复杂的计费模式、多样的硬件配置以及差异化的虚拟化方案,许多技术决策者常常陷入"…...

从CUDA核心到Tensor Core:GPU计算单元的演进与实战解析

1. CUDA核心:通用计算的基石 我第一次接触CUDA核心是在2012年做图像处理项目时。当时用GTX 680显卡做图像渲染,发现它比CPU快了近20倍,这个性能差距让我震惊。后来才知道,这要归功于显卡里密密麻麻的CUDA核心。 CUDA核心本质上就是…...

OpenClaw调试技巧:nanobot镜像的日志分析与问题定位

OpenClaw调试技巧:nanobot镜像的日志分析与问题定位 1. 为什么需要关注OpenClaw日志 上周我在本地部署nanobot镜像时遇到一个诡异现象:OpenClaw能正常接收飞书消息,但执行自动化任务时总在"思考阶段"卡住。这个问题困扰了我两天&…...

Markdown Viewer 突破限制:全新自定义主题功能释放创作潜能

Markdown Viewer 突破限制:全新自定义主题功能释放创作潜能 【免费下载链接】markdown-viewer Markdown Viewer / Browser Extension 项目地址: https://gitcode.com/gh_mirrors/ma/markdown-viewer 副标题:如何通过自定义主题功能实现文档视觉体…...

深入浅出:图解程序控制、中断和DMA的工作原理与性能差异

深入浅出:图解程序控制、中断和DMA的工作原理与性能差异 想象你在一家餐厅点餐:第一种方式是服务员每隔30秒就来问你"好了吗";第二种是你按服务铃,服务员立刻过来;第三种是厨房直接把菜送到你桌上——这正是…...

2026大模型应用爆发:504个案例揭示行业变革新机遇!

2025年,大模型技术如同一颗璀璨的新星,在各行各业绽放出耀眼光芒。从互联网、金融到能源制造、交通运输,再到医疗、教育、公共服务,展现出前所未有的活力和潜力。 大模型的应用不仅改变了企业的运营模式,提升了企业的竞…...

智慧医疗泡罩药板药片缺失缺陷检测数据集VOC+YOLO格式1300张3类别

注意数据集中图片大约500张是原图剩余为增强图片数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件)图片数量(jpg文件个数):1300标注数量(xml文件个数):1300…...