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

别再裸奔了!给若依前后端分离项目加上AES接口加密(Vue3 + Spring Boot保姆级配置)

若依框架前后端分离项目AES接口加密实战指南在当今数据安全日益重要的环境下企业级应用开发中接口传输的安全性已成为不可忽视的一环。许多开发者在使用若依这类优秀框架时往往只关注功能实现而忽略了数据传输过程中的安全隐患。本文将带您从零开始为若依前后端分离项目打造一套完整的AES接口加密方案涵盖Vue3前端到Spring Boot后端的全链路配置。1. 为什么需要接口加密想象一下当用户登录时用户名和密码以明文形式在网络中传输当查询个人隐私数据时身份证号、手机号等敏感信息直接暴露在请求响应中——这无异于在互联网上裸奔。接口加密的核心价值在于防止敏感数据泄露即使请求被拦截攻击者也无法直接获取有效信息抵御中间人攻击加密后的数据难以被篡改或伪造满足合规要求许多行业规范明确要求数据传输必须加密提示AES(高级加密标准)作为对称加密算法在性能和安全性之间取得了良好平衡是接口加密的理想选择。2. 前端加密配置(Vue3)2.1 安装与基础配置首先在Vue3项目中安装crypto-js库npm install crypto-js --save # 如遇网络问题可使用 cnpm install crypto-js --save创建src/utils/aes.js工具类import CryptoJS from crypto-js // 生成随机16位AES密钥 export const generateAESKey () { const chars 0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ return Array(16).fill(0) .map(() chars.charAt(Math.floor(Math.random() * chars.length))) .join() } // AES加密 export const encrypt (data, key) { const keyBytes CryptoJS.enc.Utf8.parse(key) const dataBytes CryptoJS.enc.Utf8.parse( typeof data object ? JSON.stringify(data) : data ) const encrypted CryptoJS.AES.encrypt(dataBytes, keyBytes, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 }) return encrypted.toString() } // AES解密 export const decrypt (ciphertext, key) { const keyBytes CryptoJS.enc.Utf8.parse(key) const decrypted CryptoJS.AES.decrypt(ciphertext, keyBytes, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 }) return CryptoJS.enc.Utf8.stringify(decrypted).toString() }2.2 请求拦截器改造修改src/utils/request.js添加加密逻辑import { encrypt, decrypt } from ./aes // 从环境变量获取配置 const AES_KEY import.meta.env.VITE_APP_AES_KEY const ENCRYPT_ENABLED import.meta.env.VITE_APP_ENCRYPT_ENABLED true // 请求拦截器 service.interceptors.request.use(config { if (ENCRYPT_ENABLED config.data) { config.data encrypt(config.data, AES_KEY) config.headers[X-Encrypted] true } return config }) // 响应拦截器 service.interceptors.response.use(response { if (ENCRYPT_ENABLED response.data response.headers[content-type]?.includes(application/json)) { try { response.data JSON.parse(decrypt(response.data, AES_KEY)) } catch (e) { console.error(解密失败:, e) } } return response.data })3. 后端加密配置(Spring Boot)3.1 过滤器实现创建解密过滤器DecryptionFilterimport javax.servlet.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.util.List; public class DecryptionFilter implements Filter { private final AES aes; private final boolean enabled; private final ListString excludeUrls; public DecryptionFilter(String key, boolean enabled, ListString excludeUrls) { this.aes new AES(key.getBytes()); this.enabled enabled; this.excludeUrls excludeUrls; } Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest httpRequest (HttpServletRequest) request; if (!enabled || shouldExclude(httpRequest.getRequestURI())) { chain.doFilter(request, response); return; } // 包装请求和响应 DecryptionRequestWrapper requestWrapper new DecryptionRequestWrapper(httpRequest, aes); EncryptionResponseWrapper responseWrapper new EncryptionResponseWrapper((HttpServletResponse) response); chain.doFilter(requestWrapper, responseWrapper); // 加密响应 if (responseWrapper.getContentType() ! null responseWrapper.getContentType().contains(application/json)) { String encrypted aes.encryptBase64(responseWrapper.getContent()); response.getWriter().write(encrypted); } } private boolean shouldExclude(String uri) { return excludeUrls.stream().anyMatch(uri::startsWith); } }3.2 请求/响应包装器实现请求包装器DecryptionRequestWrapperpublic class DecryptionRequestWrapper extends HttpServletRequestWrapper { private final String decryptedBody; public DecryptionRequestWrapper(HttpServletRequest request, AES aes) throws IOException { super(request); String encrypted IOUtils.toString(request.getReader()); this.decryptedBody encrypted.isEmpty() ? : aes.decryptStr(encrypted); } Override public BufferedReader getReader() { return new BufferedReader(new StringReader(decryptedBody)); } // 其他需要重写的方法... }实现响应包装器EncryptionResponseWrapperpublic class EncryptionResponseWrapper extends HttpServletResponseWrapper { private final ByteArrayOutputStream outputStream new ByteArrayOutputStream(); private PrintWriter writer; public EncryptionResponseWrapper(HttpServletResponse response) { super(response); } Override public ServletOutputStream getOutputStream() { return new ServletOutputStream() { Override public void write(int b) { outputStream.write(b); } // 其他必要方法实现... }; } public String getContent() { return outputStream.toString(StandardCharsets.UTF_8); } }3.3 Spring配置在配置类中注册过滤器Configuration public class FilterConfig { Value(${encrypt.enabled:false}) private boolean enabled; Value(${encrypt.key}) private String key; Value(${encrypt.exclude-urls:/common/**,/profile/**}) private ListString excludeUrls; Bean public FilterRegistrationBeanDecryptionFilter decryptionFilter() { FilterRegistrationBeanDecryptionFilter registration new FilterRegistrationBean(); registration.setFilter(new DecryptionFilter(key, enabled, excludeUrls)); registration.addUrlPatterns(/*); registration.setOrder(Ordered.HIGHEST_PRECEDENCE); return registration; } }4. 密钥管理与环境配置4.1 前端环境变量在项目根目录创建.env文件VITE_APP_AES_KEYYour16ByteAESKey123 VITE_APP_ENCRYPT_ENABLEDtrue4.2 后端配置文件application.yml配置encrypt: enabled: true key: Your16ByteAESKey123 exclude-urls: - /common/** - /profile/** - /druid/**4.3 密钥安全最佳实践不要硬编码始终通过环境变量或配置中心管理密钥区分环境开发、测试、生产环境使用不同密钥定期轮换建立密钥轮换机制但要注意历史数据解密问题最小权限仅对敏感接口启用加密静态资源等可排除5. 常见问题排查5.1 前端常见问题问题1加密后后端无法解密检查前后端密钥是否一致确认加密模式(ECB/CBC)和填充方式(PKCS7)一致查看网络请求原始数据确认传输过程中是否被修改问题2性能明显下降只对必要接口启用加密考虑使用Web Worker处理加密解密检查是否重复加密/解密5.2 后端常见问题问题1过滤器不生效检查过滤器顺序确保它在安全过滤器之前确认URL模式配置正确检查Spring Boot自动配置是否冲突问题2解密失败确认请求Content-Type为application/json检查是否有其他过滤器修改了请求体调试查看原始加密字符串是否完整6. 进阶优化建议动态密钥协商实现密钥定期更换机制避免长期使用同一密钥混合加密方案结合RSA非对称加密传输AES密钥提升安全性请求签名验证添加时间戳和签名防止重放攻击性能监控添加加密解密的耗时统计及时发现性能瓶颈白名单机制基于用户角色动态决定是否加密在实际项目中我们曾遇到一个典型案例某金融类应用在启用加密后发现某些安卓设备请求成功率显著下降。经过排查发现是低端设备加密计算耗时过长导致请求超时。最终通过优化加密策略仅在WiFi环境下启用强加密解决了问题。

相关文章:

别再裸奔了!给若依前后端分离项目加上AES接口加密(Vue3 + Spring Boot保姆级配置)

若依框架前后端分离项目AES接口加密实战指南 在当今数据安全日益重要的环境下,企业级应用开发中接口传输的安全性已成为不可忽视的一环。许多开发者在使用若依这类优秀框架时,往往只关注功能实现而忽略了数据传输过程中的安全隐患。本文将带您从零开始&a…...

D2: AI 工具的 ROI 评估框架(附 Excel 模板)

文章目录 D2: AI 工具的 ROI 评估框架(附 Excel 模板) 🎯 为什么这个话题重要? 现实痛点 真实案例 本章价值 核心内容 一、ROI 评估的核心公式 直接收益(可量化) 间接收益(需估算) 显性成本(必须计算) 隐性成本(最容易被低估) 风险成本(必须量化) 二、五维评估模…...

任务管理器怎么打开?【图文讲解】电脑卡死怎么关程序?任务管理器快捷键?电脑结束任务快捷键?6 种超简单方法,电脑卡死一键救急!

(1)问题背景 谁没碰到过电脑当场 “摆烂” 的崩溃时刻?软件卡死不动、页面关不掉、鼠标点啥都没反应,整个电脑卡成 PPT,急得人直跺脚! 这时候能救电脑于水火的,只有任务管理器。它就像电脑的急…...

BFF 架构决策与落地实践:从第一性原理到工程取舍

在主导过多个前后端分离项目的架构演进后,我对 BFF 这一层有了更系统的审视。它并非一个必须存在的组件,而是在特定约束下为解决特定问题而产生的架构模式。理解它,需要回到问题本源,厘清收益与代价,再谈如何落地。 一…...

【入门C++语法】第3章 输入cin

第3章 输入cin 一、 输入指令 C的输入指令&#xff1a;cin >> cin >> a;作用&#xff1a;读入一个变量&#xff0c;存储在变量a中 二、 完整示例程序 #include <iostream> using namespace std;int main() {int a,b;cin >> a >> b;cout <<…...

2026年工程AI动画框架:USD+知识图谱新标准

针对“2026年工程AI动画框架是否会形成基于USD知识图谱的统一语义标准”这一问题&#xff0c;答案是&#xff1a;到2026年&#xff0c;形成全球性、强制性的统一标准可能性较低&#xff0c;但以USD为几何与场景描述基础、以领域知识图谱为语义增强与推理层的“事实性”融合架构…...

ROS Melodic下,手把手教你用MoveIt Setup Assistant配置带夹爪的机械臂(附Gazebo仿真避坑点)

ROS Melodic机械臂配置实战&#xff1a;从MoveIt Setup Assistant到Gazebo仿真的全流程解析 在工业自动化和服务机器人领域&#xff0c;机械臂的运动规划一直是核心挑战。ROS Melodic作为长期支持版本&#xff0c;其MoveIt框架的配置流程与早期版本存在显著差异。本文将深入剖析…...

毕业论文排版救星!Paperxie 一键搞定 4000 + 高校格式,本科生再也不用熬夜改格式了

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/科研绘图https://www.paperxie.cn/format/typesettinghttps://www.paperxie.cn/format/typesetting 一、写在前面&#xff1a;被论文格式支配的恐惧&#xff0c;你一定懂 本科毕业论文的最后一关&#xff…...

在 ADT 里把当前焦点对象直接做成可点击清单,基于 HTML 结果的 Focused Objects Display IDE Action 实战

你在 Eclipse 版 ADT 里写代码时,真正高频的动作往往不是再新建一个对象,而是快速看清楚当前到底选中了什么。编辑器里盯着一个类,Project Explorer 里又顺手多选了几个对象,或者传输组织器里正在核对一个请求里的条目,这时候如果能有一个小动作,把当前焦点里的对象直接读…...

【限时解禁】SITS2026评测套件V1.0完整数据集+评估Pipeline(含中文细粒度标注子集)

第一章&#xff1a;SITS2026发布&#xff1a;多模态大模型评测集 2026奇点智能技术大会(https://ml-summit.org) 评测集设计目标 SITS2026&#xff08;Singularity Intelligence Test Suite 2026&#xff09;是面向下一代多模态大模型构建的综合性基准评测集&#xff0c;聚焦…...

计算机网络之TCP和UDP的底层机制

文章目录 1. TCP和UDP区别&#xff1f;2.TCP为什么可靠传输3. 怎么用UDP实现HTTP&#xff1f;4. TCP粘包怎么解决5. 滑动窗口6. 拥塞控制 1. TCP和UDP区别&#xff1f; TCP&#xff1a; 报头 TCP发送数据 客户端&#xff1a; #include <iostream> #include <strin…...

基于深度学习的苹果叶片病虫害识别系统,resnet50,vgg16,resnet34【pytorch框架,python源码】

更多图像分类、图像识别、目标检测、图像分割&#xff0c;图像检索等项目可从主页查看 功能演示(要看shi pin下面的简介)&#xff1a; https://www.bilibili.com/video/BV1Bs4XzcEdH/?spm_id_from333.1387.homepage.video_card.click&vd_source95b9b70984596ccebdb2780f0…...

2026年安卓APP安全加固公司哪家好?从技术、性能到合规的深度选型指南

选错安卓APP安全加固公司&#xff0c;后果可能比不加固更严重——应用商店审核被拒、上线后用户疯狂反馈闪退、核心代码被逆向破解导致数据泄露。更棘手的是&#xff0c;当你拿着加固报告去应对等保测评时&#xff0c;可能因为加固方案不被认可而功亏一篑。这些都不是危言耸听&…...

S32K144外部中断实战:用按键控制LED,手把手教你避开中断标志位清除的坑

S32K144外部中断实战&#xff1a;从按键消抖到标志位管理的完整解决方案 在嵌入式开发中&#xff0c;外部中断是实现实时响应的关键机制。S32K144作为NXP面向汽车电子和工业控制的主力MCU&#xff0c;其中断系统的灵活性和可靠性备受开发者青睐。但看似简单的按键中断控制LED背…...

有孩家庭接送场景混动车型实证测评:座舱健康与续航便捷性核心指标对比研究

摘要在城市通勤与萌娃接送双场景叠加的用车需求下&#xff0c;座舱健康&#xff08;甲醛 / 异味控制、空气净化&#xff09;与出行便捷性&#xff08;纯电续航、亏电油耗、场景适配收纳&#xff09;已成为有孩家庭选购混动 SUV 的核心决策指标。针对当前市场车型 “健康参数标注…...

源码解读:拿下顶会最佳论文的重建式VLA,是如何实现的!

“如果模型能重建它&#xff0c;就说明它真正注意到了它” ——源码级解析 目录 01 问题的起点&#xff1a;为什么 VLA 需要“重建”&#xff1f; 02 系统架构总览 03 核心技术一&#xff1a;DiT 扩散去噪与 adaLN-Zero 条件注入 条件的构建与融合 adaLN-Zero 注入逻…...

5篇2章12节:诊断试验准确性研究与多阈值Meta分析方法(下篇:可视计算)

多阈值 Meta 分析通过整合全阈值范围内的诊断效能数据,为临床实践提供更全面的证据支持,但数据转换的复杂性与结果可视化的直观性一直是技术痛点。本文作为诊断试验准确性研究系列下篇,接着全面讲解可视化绘图和诊断统计量计算 。 一、plot () 函数 diagmeta包的plot()函数…...

探索JavaScript中的生命游戏:细胞自动机的实现

探索JavaScript中的生命游戏:细胞自动机的实现 在计算机科学中,细胞自动机(Cellular Automata)是一个非常有趣的研究领域,而康威生命游戏(Conway’s Game of Life)则是其中最著名的例子之一。今天我们将探讨如何使用JavaScript来实现这个经典的自动机模型,并特别关注其…...

终极指南:5分钟快速掌握B站视频转文字开源工具bili2text

终极指南&#xff1a;5分钟快速掌握B站视频转文字开源工具bili2text 【免费下载链接】bili2text Bilibili视频转文字&#xff0c;一步到位&#xff0c;输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 还在为手动记录B站视频内容而烦恼吗&…...

快速掌握 FastAPI 路由:从基础到进阶

前言 FastAPI 是一个现代的、快速&#xff08;高性能&#xff09;的 Web 框架&#xff0c;用于构建 API。它基于 Python 类型注解&#xff0c;支持自动生成 OpenAPI 文档&#xff0c;且性能优越&#xff0c;适合构建高效的 Web API。本文将详细介绍如何在 FastAPI 中使用路由处…...

生成式AI数据飞轮构建:从0到规模化复利增长的6个关键杠杆(附某金融大模型真实飞轮增速曲线)

第一章&#xff1a;生成式AI应用数据飞轮构建 2026奇点智能技术大会(https://ml-summit.org) 生成式AI应用的数据飞轮并非天然形成&#xff0c;而是依赖闭环反馈机制驱动的持续演进系统&#xff1a;用户交互产生真实行为数据 → 数据经清洗与标注强化模型能力 → 模型升级提升…...

C 语言教程

C 语言教程C 语言是一种通用的、面向过程式的计算机程序设计语言。1972 年&#xff0c;为了移植与开发 UNIX 操作系统&#xff0c;丹尼斯里奇在贝尔电话实验室设计开发了 C 语言。 C 语言是一种广泛使用的计算机语言&#xff0c;它与 Java 编程语言一样普及&#xff0c;二者在现…...

揭秘多模态餐饮推荐系统落地难题:从BERT-Vision融合到实时推理延迟压降至89ms的实战路径

第一章&#xff1a;2026奇点智能技术大会&#xff1a;多模态餐饮推荐 2026奇点智能技术大会(https://ml-summit.org) 在2026奇点智能技术大会上&#xff0c;多模态餐饮推荐系统成为核心展示场景之一。该系统融合用户历史行为、实时图像&#xff08;如菜品照片&#xff09;、语…...

汽车c语言是什么?

汽车C语言主要是指在汽车电子系统中使用的C语言编程技术。以下是关于汽车C语言的详细解释&#xff1a; 1.定义与用途&#xff1a; 汽车C语言指的是在汽车制造和软件开发中&#xff0c;特别是在嵌入式系统编程中广泛使用的C语言。 它被用于编写控制汽车各种电子设备的软件&#…...

DeepSeek角色扮演指令终极指南:解锁AI自由对话新境界

1. DeepSeek角色扮演的核心原理 DeepSeek的角色扮演功能之所以强大&#xff0c;关键在于它突破了传统AI对话的边界。传统AI对话往往受限于预设的道德准则和安全审查机制&#xff0c;而DeepSeek通过特殊的指令设计&#xff0c;实现了真正意义上的自由对话体验。这就像给AI装了一…...

联邦学习落地金融风控:当银行遇到电商,如何在不共享数据的前提下联合建模?

联邦学习在金融风控中的实战&#xff1a;银行与电商的数据协作新范式 想象一下这样的场景&#xff1a;一家商业银行拥有客户的信用评分和还款记录&#xff0c;而某大型电商平台则积累了同一批用户的消费行为、浏览偏好和支付习惯。这两组数据如果能够联合建模&#xff0c;将大幅…...

微信小程序里用H5预览PDF,我为什么放弃了原生组件选了pdf.min.js?

微信小程序PDF预览方案深度解析&#xff1a;为何pdf.min.js成为技术选型最优解&#xff1f; 在微信小程序生态中实现PDF预览功能时&#xff0c;开发者往往面临技术路线的关键抉择。原生组件、云服务方案与H5渲染引擎各具特点&#xff0c;但经过多次实战验证&#xff0c;基于pdf…...

HWSDv2.0土壤数据怎么用?从全球1km栅格到你的研究区,这份ArcGIS Pro掩膜裁剪指南请收好

HWSDv2.0土壤数据区域提取实战&#xff1a;ArcGIS Pro高效掩膜裁剪技巧 当全球1公里分辨率的HWSDv2.0土壤数据遇上具体研究区域&#xff0c;如何快速提取目标范围的数据成为科研工作者的首要挑战。本文将手把手教你使用ArcGIS Pro完成从全局到局部的精准数据裁剪&#xff0c;让…...

QLabel的四种内容呈现模式

1. QLabel的多面手特性&#xff1a;不只是显示文字 第一次接触Qt开发时&#xff0c;很多人会把QLabel简单理解为一个"文字标签控件"。直到我在实际项目中需要显示动态图表时&#xff0c;才发现这个看似简单的控件竟然藏着这么多玩法。QLabel本质上是一个多功能显示容…...

Codex 前端实战:AI 能画出设计稿,也能写代码,但如何让它不再“像 AI 做的”?

Codex 前端实战:AI 能画出设计稿,也能写代码,但如何让它不再“像 AI 做的”? 上周我用 Codex 把一份 Figma 设计稿丢给它,三分钟生成了一个完整的前端页面。同事们看完说:“这个看起来不太像 AI 做的。” 这句话很有意思。默认情况下,Codex 生成的前端代码确实有一股“…...