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

从若依(RuoYi)漏洞看SpringBoot项目常见安全坑:开发中如何避免SQL注入与路径遍历?

从若依漏洞剖析SpringBoot项目安全防御体系SQL注入与路径遍历实战解决方案最近在代码审计中遇到几个典型漏洞案例让我意识到很多开发者对SpringBoot项目的安全防护仍停留在理论层面。以若依(RuoYi)这类流行框架为例其SQL注入和任意文件下载漏洞本质上反映了开发中的共性安全隐患。今天我们就从这两个高频漏洞入手拆解背后的安全逻辑并给出可落地的防御方案。1. SQL注入漏洞深度解析与MyBatis防御实践去年参与某金融系统渗透测试时发现一个与若依类似的漏洞通过orderByColumn参数注入恶意SQL片段。这种漏洞的根源往往在于动态SQL拼接的失控。1.1 MyBatis中的危险操作模式问题常出现在以下场景Select(SELECT * FROM users WHERE id ${id}) User getUserById(Param(id) String id);这里的${}直接拼接参数相当于敞开大门迎接注入攻击。我曾用类似漏洞在测试环境获取过整个用户表数据。安全编码对比表危险写法安全写法防护原理${param}#{param}预编译参数化查询SELECT * FROM tableName动态SQL标签白名单校验拼接ORDER BYOrderBy注解固定排序字段1.2 MyBatis-Plus的安全增强方案新版若依已采用MyBatis-Plus其安全特性值得借鉴// 安全分页示例 PageUser page new Page(1, 10); LambdaQueryWrapperUser wrapper Wrappers.lambdaQuery() .eq(User::getRoleKey, admin) .orderByAsc(User::getCreateTime); userMapper.selectPage(page, wrapper);关键提示即使使用Lambda表达式也要警惕前端传入的排序字段名建议采用枚举限定public enum SafeOrderFields { CREATE_TIME(create_time), USERNAME(username); private final String columnName; // ... }2. 路径遍历漏洞防御体系构建那个任意下载/etc/passwd的漏洞让我印象深刻。问题出在路径拼接时未做规范化处理2.1 安全的文件路径处理规范// 危险写法 String filePath /downloads/ userInput; // 安全方案 Path safePath Paths.get(/downloads/) .resolve(Paths.get(userInput).normalize()) .normalize(); if (!safePath.startsWith(/downloads/)) { throw new IllegalAccessException(路径越界); }防御矩阵输入校验层白名单校验文件扩展名正则过滤../等特殊字符处理层使用Paths.normalize()规范化设置根路径锚点系统层文件服务独立部署最小权限原则设置目录权限2.2 SpringBoot资源处理最佳实践建议采用ResourceHttpRequestHandlerConfiguration public class SafeDownloadConfig implements WebMvcConfigurer { Override public void addResourceHandlers(ResourceHandlerRegistry registry) { registry.addResourceHandler(/safe-download/**) .addResourceLocations(file:/secured-files/) .setUseLastModified(true); } }3. 参数校验防御体系设计很多漏洞本质是参数校验缺失。Spring Validation的进阶用法值得掌握3.1 分层校验策略public class UserDTO { NotBlank(message 角色名不能为空) Pattern(regexp ^[a-zA-Z0-9_]{4,20}$, message 包含非法字符) private String roleKey; SafePath // 自定义校验注解 private String filePath; }自定义校验注解示例Constraint(validatedBy SafePathValidator.class) Retention(RUNTIME) public interface SafePath { String message() default 非法路径格式; Class?[] groups() default {}; Class? extends Payload[] payload() default {}; }3.2 全局异常处理增强RestControllerAdvice public class SecurityExceptionHandler { ExceptionHandler(BindException.class) public ResponseEntityResult handleValidationError(BindException ex) { ListString errors ex.getFieldErrors().stream() .map(f - f.getField() : f.getDefaultMessage()) .collect(Collectors.toList()); return ResponseEntity.badRequest() .body(Result.fail(400, 参数校验失败, errors)); } }4. 纵深防御体系构建单一防护层总有被绕过的风险需要建立多层防御4.1 安全编码检查清单[ ] 所有SQL语句使用参数化查询[ ] 文件操作进行路径规范化校验[ ] 关键操作添加审计日志[ ] 定期依赖库漏洞扫描[ ] 接口权限二次校验4.2 监控与应急方案建议配置以下监控指标# 日志监控规则示例 alert: SQL_Error_Injection_Attempt expr: rate(log_messages{message~.*SQL syntax.*}[5m]) 0 for: 1m labels: severity: critical annotations: summary: Possible SQL injection attempt detected5. 实战中的经验之谈在最近一次系统加固中我们发现即使使用了参数化查询某些复杂查询仍可能存在注入风险。例如MyBatis的if标签配合${}使用时!-- 仍有风险的写法 -- select idfindUsers resultTypeUser SELECT * FROM users where if testorderBy ! null ORDER BY ${orderBy} /if /where /select最终我们采用的解决方案是建立排序字段白名单使用枚举限定可选排序方式在Mapper接口层做二次校验另一个容易忽视的点是日志打印曾经遇到过敏感数据通过异常信息泄露的情况。现在我们会统一处理ControllerAdvice public class GlobalExceptionHandler { ExceptionHandler(Exception.class) public ResponseEntityErrorResponse handleException(Exception ex) { log.error(系统异常, sanitizeException(ex)); return ResponseEntity.status(500) .body(new ErrorResponse(系统繁忙)); } private Exception sanitizeException(Exception raw) { // 移除异常中的敏感信息 return new SanitizedException(raw.getMessage()); } }

相关文章:

从若依(RuoYi)漏洞看SpringBoot项目常见安全坑:开发中如何避免SQL注入与路径遍历?

从若依漏洞剖析SpringBoot项目安全防御体系:SQL注入与路径遍历实战解决方案 最近在代码审计中遇到几个典型漏洞案例,让我意识到很多开发者对SpringBoot项目的安全防护仍停留在理论层面。以若依(RuoYi)这类流行框架为例,其SQL注入和任意文件下…...

移相全桥变换器原理及优缺点

一、引言在中大功率 DC-DC 变换领域(100W~10kW),移相全桥(Phase-Shifted Full-Bridge, PSFB)变换器凭借软开关特性、高效率、高功率密度、低电磁干扰等优势,成为当之无愧的主流拓扑。它完美解决了硬开关全桥…...

嵌入式系统事件控制与连续处理架构设计

1. 嵌入式系统的事件控制连续处理架构解析 在工业自动化领域,嵌入式系统需要同时应对两种截然不同的处理需求:一方面要持续不断地处理传感器采集的实时数据流,另一方面又必须及时响应各种异步事件(如用户指令、设备状态变化等&…...

mysql如何进行全量数据库备份_mysqldump工具的使用技巧

备份前必须确认用户具备SELECT、LOCK TABLES、RELOAD权限,且MySQL未启用read_onlyON、max_allowed_packet足够大;全量备份需加--routines、--events、--triggers、--single-transaction和--set-gtid-purgedOFF。备份前必须确认的三个权限和状态用 mysqld…...

宝塔面板SSH提示连接被拒绝_检查服务器端口开关

SSH连接被拒绝需依次排查sshd服务状态、系统防火墙、宝塔防火墙及云平台安全组:先用systemctl status sshd确认运行,再检查firewalld/ufw和宝塔安全页面端口放行,最后核查云厂商安全组规则是否开放22端口。宝塔面板SSH连接被拒绝,…...

别再死记硬背了!用Python实战案例带你搞懂决策树、随机森林到XGBoost的进化史

从决策树到XGBoost:用Python实战演绎机器学习模型的进化之路 在机器学习领域,树模型家族以其直观的解释性和出色的预测能力,始终占据着重要地位。但很多学习者在接触决策树、随机森林、XGBoost等一系列算法时,常常陷入孤立记忆公式…...

golang如何实现滑动窗口计数器_golang滑动窗口计数器实现思路

滑动窗口计数器不能只用map定时清理,因会漏统计非整点对齐的请求;必须保留带时间戳事件或时间分片,常用环形数组实现,按需shift比ticker更精准高效。滑动窗口计数器为什么不能只用 map 定时清理直接用 map[string]int 存请求次数…...

保姆级教程:Windows下ComfyUI环境配置,从驱动到CUDA再到PyTorch版本一条龙搞定

Windows下ComfyUI环境配置全攻略:从驱动到CUDA再到PyTorch版本一站式解决方案 在AI绘画领域,ComfyUI以其强大的功能和灵活的节点式操作赢得了众多用户的青睐。然而,对于许多初学者来说,环境配置往往成为第一道难以逾越的门槛。本文…...

生成式AI应用搜索排名暴跌?5个致命误区正在毁掉你的流量,立即排查!

第一章:生成式AI应用搜索排名暴跌的真相诊断 2026奇点智能技术大会(https://ml-summit.org) 近期大量生成式AI工具类网站在Google、Bing等主流搜索引擎中出现断崖式排名下滑,部分产品关键词自然流量下降超70%。这一现象并非偶然算法更新所致&#xff0c…...

深度学习之移动端部署(一)--MobileNetV1 轻量化设计解析

1. 为什么移动端需要轻量化模型? 当你用手机拍照时,是否想过背后的AI是如何实时识别人脸或物体的?这背后离不开轻量化神经网络的支持。传统CNN如VGG16拥有1.38亿参数,相当于500本《新华字典》的文字量,而MobileNetV1仅…...

从零上手Apache Zeppelin:一站式交互式数据分析平台实战

1. Apache Zeppelin初探:数据分析师的瑞士军刀 第一次接触Apache Zeppelin是在三年前的一个数据仓库迁移项目里。当时团队需要同时处理Hive、Spark和MySQL三种数据源,每天在不同终端间切换得头晕眼花。直到有位同事扔给我一个8080端口的链接:…...

Matlab 5G NR信道建模实战:CDL信道API参数配置与性能分析

1. 5G NR信道建模入门:为什么选择CDL模型? 如果你正在研究5G通信系统,信道建模绝对是你绕不开的关键环节。我在去年参与的一个毫米波通信项目中,就深刻体会到准确信道建模的重要性。当时我们尝试了多种建模方法,最终发…...

实战指南:基于Pytorch与BiSeNet,从零构建无人机遥感图像语义分割数据集训练流程

1. 环境准备与项目初始化 第一次接触无人机遥感图像处理时,我被高分辨率图像中的丰富细节震撼到了。但随之而来的问题是:如何在普通显卡上高效处理这些"庞然大物"?经过多次实践,我总结出一套适合个人开发者的解决方案。…...

WaveTools鸣潮工具箱:终极免费工具让游戏体验全面升级

WaveTools鸣潮工具箱:终极免费工具让游戏体验全面升级 【免费下载链接】WaveTools 🧰鸣潮工具箱 项目地址: https://gitcode.com/gh_mirrors/wa/WaveTools 你是否正在寻找一款能够彻底释放《鸣潮》游戏潜力的专业级工具?WaveTools鸣潮…...

KMS_VL_ALL_AIO:终极Windows和Office激活解决方案完整指南

KMS_VL_ALL_AIO:终极Windows和Office激活解决方案完整指南 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统激活问题烦恼吗?KMS_VL_ALL_AIO是一款开源免…...

基于深度学习的实时手语翻译系统架构设计与实现

基于深度学习的实时手语翻译系统架构设计与实现 【免费下载链接】Sign-Language-Interpreter-using-Deep-Learning A sign language interpreter using live video feed from the camera. 项目地址: https://gitcode.com/gh_mirrors/si/Sign-Language-Interpreter-using-Dee…...

WarcraftHelper终极指南:5个简单步骤让魔兽争霸3在现代Windows系统完美运行

WarcraftHelper终极指南:5个简单步骤让魔兽争霸3在现代Windows系统完美运行 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸…...

Hunyuan-MT-7B开源镜像:Pixel Language Portal与LangChain集成构建翻译Agent

Hunyuan-MT-7B开源镜像:Pixel Language Portal与LangChain集成构建翻译Agent 1. 项目概览 Pixel Language Portal(像素语言跨维传送门)是一款基于腾讯Hunyuan-MT-7B大模型构建的创新翻译工具。不同于传统翻译软件的呆板界面,它采…...

端到端 RAG 实战:用 LangChain 搭建 PDF 问答系统

一、今天要做什么 前 6 天我们逐一学习了 RAG 的每个核心组件: Day01:RAG 整体架构Day02:文本分块(Chunking)Day03:Embedding 模型Day04:向量数据库Day05:检索策略Day06&#xff1…...

海报颜色选择指南:选对色彩,让海报更具吸引力

色彩是海报视觉传达的核心要素,比文字、图形更能快速抓住受众目光,传递情绪与信息。选对海报颜色,不仅能提升整体设计质感,还能强化信息传递效率,让海报在众多视觉素材中脱颖而出;反之,色彩搭配…...

C语言的发展及其版本

如果您是一名入门学者,或者您还不理解什么是编程语言,请查看:什么是编程语言。 如果您之前未接触任何编程语言,或者您不理解为什么学习C语言,请查看:为什么C语言是首选。 C语言于1972年11月问世&#xff0c…...

国产化迁移笔记:在龙芯/飞腾的银河麒麟V10中,为OpenJDK 8补全Icedtea-netx插件全记录

国产化迁移实战:在银河麒麟V10中为OpenJDK 8补全Icedtea-netx插件全流程解析 当企业级应用从传统x86架构向国产化平台迁移时,Java Web Start技术的兼容性问题往往成为拦路虎。最近在将某金融系统迁移到龙芯3A5000平台时,我们遇到了一个典型场…...

运放稳定性分析:电阻电容组合对波特图零点极点的影响

1. 从洗澡水温度理解波特图与零极点 想象一下你正在调节淋浴的水温。刚开始转动混水阀时,水温变化很快,但随着接近舒适温度,变化速度会逐渐放缓。这个过程中有两个关键点:一个是水温开始变化的起始点(类似零点&#xf…...

从SAD到SGBM:双目立体视觉核心匹配算法演进与实战解析

1. 双目立体视觉的基石:为什么需要匹配算法? 第一次接触双目立体视觉时,我盯着左右两个摄像头拍摄的画面看了半天也没想明白:明明是两个普通2D图像,怎么就能变出深度信息?后来才发现,这个魔术的…...

别再只用Image Asset了!Android Studio图标生成的隐藏技巧与实战避坑

别再只用Image Asset了!Android Studio图标生成的隐藏技巧与实战避坑 在安卓应用开发中,图标作为用户对产品的第一印象,其适配质量直接影响应用的专业度和用户体验。虽然Android Studio的Image Asset工具简化了图标生成流程,但许多…...

幻境·流金入门必看:DiffSynth-Studio+玄金美学环境搭建详解

幻境流金入门必看:DiffSynth-Studio玄金美学环境搭建详解 “流光瞬息,影画幻成。” 你是否曾幻想过,只需输入一段文字描述,就能在十几秒内获得一张细节丰富、质感堪比电影画面的高清图像?这听起来像是科幻电影里的场景…...

ANSYS面载荷施加避坑指南:SFL、SFA、SFE命令的区别与SFFRAN转换时机

ANSYS面载荷施加避坑指南:SFL、SFA、SFE命令的区别与SFFRAN转换时机 在ANSYS结构分析中,面载荷的施加是建模过程中最容易出现问题的环节之一。许多工程师虽然掌握了基本命令语法,但在实际应用中常常遇到载荷显示异常、计算结果不符预期等问题…...

Qwen3-32B智能问答系统搭建:基于API的快速开发指南

Qwen3-32B智能问答系统搭建:基于API的快速开发指南 1. 环境准备与快速部署 在开始使用Qwen3-32B构建智能问答系统前,我们需要完成基础环境准备。Qwen3-32B作为320亿参数的大型语言模型,其API调用方式既简单又高效。 1.1 获取API访问凭证 …...

Matlab 2023b最新版安装指南:从下载到激活的完整流程(附百度网盘资源)

MATLAB 2023b 高效安装与配置全攻略:工程师的实战手册 在科研计算与工程仿真领域,MATLAB始终保持着不可替代的地位。2023b版本带来的性能优化和新工具箱让数据处理效率提升显著——根据MathWorks官方测试报告,矩阵运算速度比前代提升23%&…...

SLAM从未消失,只是在各产业中悄悄完成「位置下沉、角色重组」

对未来SLAM形态的核心判断下沉为底层基础能力:未来SLAM不会以完整独立模块存在,其核心能力将拆解融入定位、建图等各环节,实现底层下沉。混合式系统成主流选择:纯几何方法在可解释性、效率和稳定性上仍有优势,而融合多…...