应用层漏洞实战防护:SQL 注入、XSS、文件上传漏洞一站式加固方案

SQL 注入防护

使用参数化查询或预编译语句替代字符串拼接。例如在Java中采用PreparedStatement,PHP中使用PDO绑定参数:

java 复制代码
String sql = "SELECT * FROM users WHERE username = ?";
PreparedStatement stmt = connection.prepareStatement(sql);
stmt.setString(1, userInput);

ORM框架如Hibernate、MyBatis等内置防注入机制。避免直接拼接SQL语句,特殊字符需转义处理,如MySQL的mysql_real_escape_string()

最小权限原则配置数据库账户权限,禁止应用使用root账户。启用WAF规则过滤常见注入特征,如UNION SELECT--等注释符。

XSS跨站脚本防护

输出数据时进行HTML实体编码,例如将<转为&lt;。前端框架如React/Vue默认提供XSS防护,避免使用v-htmldangerouslySetInnerHTML

设置HTTP头Content-Security-Policy限制脚本来源:

复制代码
Content-Security-Policy: default-src 'self'; script-src 'self' https://trusted.cdn.com

表单提交启用验证码防止自动化攻击,Cookie标记HttpOnlySecure属性。富文本场景使用白名单过滤标签,如DOMPurify库。

文件上传漏洞防护

限制上传文件扩展名至业务必需类型,如仅允许.jpg,.png。服务端校验文件头魔数而非扩展名,防止伪装攻击。

存储文件时重命名随机化,避免用户控制文件名。禁用上传目录的脚本执行权限,Nginx配置示例:

nginx 复制代码
location ^~ /uploads/ {
    deny all;
}

扫描上传文件内容是否包含恶意代码,病毒文件需隔离处理。云存储服务可启用对象版本控制与访问日志审计。

综合防护措施

定期更新应用框架与组件,修复已知漏洞。敏感操作记录详细日志,包括IP、时间戳和操作内容。

关键业务接口添加速率限制,防止暴力破解。生产环境关闭错误调试信息,避免泄露系统路径等敏感数据。

安全测试应覆盖DAST动态扫描与SAST代码审计,渗透测试模拟攻击验证防护有效性。建立应急响应流程,漏洞确认后72小时内完成修复。

相关推荐
炸炸鱼.1 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
Ronaldinho Gaúch1 小时前
MySQL基础
数据库·mysql
不剪发的Tony老师2 小时前
Noir:一款键盘驱动的现代化数据库管理工具
数据库·sql
.柒宇.3 小时前
MySQL双主同步
linux·数据库·mysql·docker
Trouvaille ~3 小时前
【MySQL篇】数据类型:存储数据的基础
android·数据库·mysql·adb·字符集·数据类型·基础入门
一 乐3 小时前
酒店预订|基于springboot + vue酒店预订系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·酒店预订系统
光泽雨4 小时前
UNION 和 UNION ALL 作用
数据库·sql
heimeiyingwang4 小时前
【架构实战】SQL调优实战:从执行计划到索引优化
数据库·sql·架构
恼书:-(空寄5 小时前
分库分表风险应对手册(生产实战版)
数据库·分库分表
XDHCOM5 小时前
ORA-06521: PL/SQL映射函数错误,权威解析Oracle报错故障修复与远程处理方案
数据库·sql·oracle