博客
关于我
【DVWA1.10】Stored Cross Site Scripting (XSS)通关笔记
阅读量:744 次
发布时间:2019-03-22

本文共 999 字,大约阅读时间需要 3 分钟。

最佳实践 - 安全评估与防御机制优化

1. 隐蔽性测试 - 隐蔽型注入回应机制

在前面的分析中,针对三个不同难度级别的防护机制进行了深入测试,最终发现了一个关键的安全漏洞:尽管message字段经过了多重过滤处理,但name字段仅去除了部分脚本标签,存在潜在的XSS安全隐患。

2. 改进方案 - 输入长度扩展与有效性检查

  • 长度控制: 原本name字段的maxlength设置为10,不仅限制了用户输入的真实需求,也导致了潜在的剪切损害。扩展到maxlength="999"更有利于正常用户输入,而不会触发数据溢出预警。

  • 有效性检查: 在提交前对name字段进行过滤,确保仅允许字母、数字和某些允许字符(如-_),防止恶意输入破坏数据库结构。

3. 改进后的安全防护机制

  • message字段:继续使用mysqli_real_escape_stringhtmlspecialchars双重过滤,确保输入中的特殊字符不会导致SQL注入或 XSS攻击。

  • name字段:采用更精准的正则表达式/[^a-zA-Z0-9_-]/,过滤掉所有不符合要求的字符,确保输入的安全性。同时,继续使用mysqli_real_escape_string对输入数据进行最终处理。

4. 防护效果验证

通过手动注入测试,发现即便修改了maxlength和过滤规则,仍然可以通过<script><img>的原始HTML标签触发XSS攻击。这表明需要采取更为全面的防护措施,包括但不限于:

  • csrf token验证: 在提交数据前后增加AntiForgeryToken,防止跨站请求伪造攻击。

  • 数据验证: 利用JavaScript验证name字段的输入合法性,阻止恶意用户输入破坏数据库。

5. 整体架构优化建议

  • 数据库连接管理: 固体使用mysqli连接,而不是频繁打开关闭数据库连接,以减少资源消耗和潜在的连接泄漏风险。

  • 错误处理: 可以采用自定义错误志gers,避免直接输出数据库错误信息,减少攻击可感知信息’.

  • 日志审计: 记录所有数据库操作和用户行为,帮助及时发现异常访问。

6. SSL/TLS部署

确保web应用程序和数据库使用SSL/TLS加密通信,防止数据在传输过程中被窃取或篡改。

7. 定期Security审计

每月至少进行一次全面的安全审计,包括代码审查、测试应ROTO技被然,确保防护机制的有效性。

转载地址:http://uvbwk.baihongyu.com/

你可能感兴趣的文章
NullPointerException Cannot invoke setSkipOutputConversion(boolean) because functionToInvoke is null
查看>>
Numix Core 开源项目教程
查看>>
NumPy 或 Pandas:将数组类型保持为整数,同时具有 NaN 值
查看>>
numpy 数组 dtype 在 Windows 10 64 位机器中默认为 int32
查看>>
numpy 数组与矩阵的乘法理解
查看>>
numpy 用法
查看>>
Numpy 科学计算库详解
查看>>
Numpy.ndarray对象不可调用
查看>>
Numpy如何使用np.umprod重写range函数中i的python
查看>>
numpy数组索引-ChatGPT4o作答
查看>>
numpy转PIL 报错TypeError: Cannot handle this data type
查看>>
NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
查看>>
oauth2-shiro 添加 redis 实现版本
查看>>
OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
查看>>
OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
查看>>
OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
查看>>
OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
查看>>
OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
查看>>
OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
查看>>
OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
查看>>