URL混淆与权限绕过技术


一、漏洞原理
  1. 前后端路径解析逻辑不一致

    • 后端框架(Spring/Shiro)自动处理特殊字符(..///),但鉴权组件(如Filter)未规范化原始URI。

    • 示例/system/login/../admin被Filter误判为白名单路径/system/login,实际解析为/admin

  2. 后缀白名单机制

    • 对静态资源后缀(.json.css)的请求未校验权限,如/api/user.json绕过鉴权。
  3. 分隔符截断逻辑

    • 分号;分割参数导致后端忽略后续内容,如/admin;123仅校验/admin部分。

二、绕过技术分类
1. 资源后缀混淆
  • 静态后缀追加:
复制代码
 GET /admin/main.css HTTP/1.1  # 利用白名单绕过鉴权

动态参数伪装

复制代码
 GET /admin?callback=test.json HTTP/1.1  # 参数伪装为静态资源
2. 路径构造与编码
  • 目录遍历(../跳转):
复制代码
 GET /system/login/../../admin HTTP/1.1  # 结合白名单路径绕过

URL编码混淆

复制代码
 ​
 GET /system/%2e%2e/admin HTTP/1.1  # 编码`.`绕过过滤

多斜杠干扰

复制代码
 GET ///admin//user HTTP/1.1  # 后端解析为`/admin/user`,但Filter未匹配
3. 协议特性与分隔符利用
  • 分号截断:
复制代码
 GET /admin;%09/user HTTP/1.1  # 分号后内容被忽略

HTTP方法篡改

复制代码
 HEAD /admin HTTP/1.1  # 后端仅校验POST/PUT方法
4. 标头伪造与参数控制
  • X-Original-URL滥用:
复制代码
 GET /public-page HTTP/1.1  
 X-Original-URL: /admin  # 后端信任标头覆盖路径

参数提权

复制代码
 POST /user/update HTTP/1.1  
 { "role_id": 2 }  # 后端未校验客户端提交的权限参数

三、实战案例
  1. Shiro权限绕过

    • 漏洞场景:构造/admin;%09绕过路径匹配逻辑。

      Payload:

复制代码
 GET /admin;jsessionid=xxx HTTP/1.1  # 分号截断绕过鉴权

Spring Security配置缺陷

  • 漏洞场景antMatchers("/admin")未覆盖子路径,访问/admin//admin.json绕过。

  • 修复方案 :使用/admin/**或启用mvcMatchers严格匹配。

路径编码绕过

  • 攻击过程:
    复制代码
     GET /%2e%2e/etc/passwd HTTP/1.1  # URL编码绕过过滤
    • 结果:成功读取系统敏感文件。

四、防御策略
  1. 路径规范化处理

    • 使用request.getServletPath()替代getRequestURI(),避免解析差异。
  2. 统一鉴权框架

    • 强制RBAC模型校验,禁止依赖单一维度(如URL或方法)。
  3. 后缀白名单限制

    • 动态接口禁用.json.css等静态资源后缀。
  4. 输入过滤与编码

    • 拦截../;%u等高危字符,解码后二次校验。
  5. 日志与监控

    • 记录含非标头(如X-Original-URL)的请求,告警异常路径访问。

五、Fuzz字典与工具
  • 常用Payload:
复制代码
 ; . .. / // %2e %0a %0d %09 .json .css /..;/ /%2e%2e/
  • 自动化工具:

    • Burp Intruder:批量测试路径混淆组合。

    • FFuf:快速遍历后缀与编码变体。


核心总结

  1. 绕过技术核心

    • 利用分号截断、路径跳转、多斜杠干扰、编码混淆等手段制造前后端解析差异。

    • 伪造标头(如X-Original-URL)或参数篡改直接绕过权限校验。

  2. 框架特性风险

    • Shiro的分号解析逻辑、Spring Security的路径匹配缺陷是常见漏洞来源。
  3. 防御核心原则

    • 路径处理标准化、权限校验多维度化、输入过滤严格化。
相关推荐
宝塔面板14 小时前
AllinSSL 一站式搞定 SSL 自动续期:永久免费,开源可自托管
网络·网络协议·ssl
csdn今天倒闭了吗14 小时前
飞牛lucky配置ipv6 ddns+ssl+反向代理
网络·网络协议·ssl
kali-Myon14 小时前
2025春秋杯网络安全联赛冬季赛-day2
python·安全·web安全·ai·php·pwn·ctf
强风79414 小时前
Linux-网络层
网络
独行soc14 小时前
2026年渗透测试面试题总结-19(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
_Johnny_15 小时前
ETCD 配额/空间告警模拟方案
网络·数据库·etcd
CHENKONG_CK15 小时前
晨控CK-LR08-E00与汇川H5U系列PLC配置MODBUSTCP通讯连接手册
linux·服务器·网络
天荒地老笑话么15 小时前
静态 IP 规划:掩码/网关/DNS 的正确组合
网络·网络协议·tcp/ip·网络安全
Tadas-Gao15 小时前
TCP粘包现象的深度解析:从协议本质到工程实践
网络·网络协议·云原生·架构·tcp
IOsetting15 小时前
金山云主机添加开机路由
运维·服务器·开发语言·网络·php