CVE-2018-15758:spring-security-oauth2 中的权限提升

严重 | 2018 年 10 月 16 日 | CVE-2018-15758

描述

Spring Security OAuth 2.3 版本(2.3.4 版本之前)、2.2 版本(2.2.3 版本之前)、2.1 版本(2.1.3 版本之前)、2.0 版本(2.0.16 版本之前)以及更老的非受支持版本在某些条件下可能容易受到权限提升攻击。恶意用户或攻击者可以精心构造对批准端点的请求,从而修改之前保存的授权请求,并在随后的批准过程中导致权限提升。如果应用程序配置为使用一个将 AuthorizationRequest 声明为控制器方法参数的自定义批准端点,则可能出现此情况。

此漏洞会影响满足以下所有要求的应用程序

  • 充当授权服务器角色(例如 @EnableAuthorizationServer
  • 使用将 AuthorizationRequest 声明为控制器方法参数的自定义批准端点

此漏洞不影响以下应用程序

  • 充当授权服务器角色并使用默认批准端点
  • 仅充当资源服务器角色(例如 @EnableResourceServer
  • 仅充当客户端角色(例如 @EnableOAuthClient

受影响的 Spring 产品和版本

  • Spring Security OAuth 2.3 至 2.3.3
  • Spring Security OAuth 2.2 至 2.2.2
  • Spring Security OAuth 2.1 至 2.1.2
  • Spring Security OAuth 2.0 至 2.0.15
  • 更老的非受支持版本也受影响

缓解措施

受影响版本的用户应采取以下缓解措施

  • 2.3.x 版本用户应升级到 2.3.4
  • 2.2.x 版本用户应升级到 2.2.3
  • 2.1.x 版本用户应升级到 2.1.3
  • 2.0.x 版本用户应升级到 2.0.16
  • 更旧版本应升级到受支持的分支

无需其他缓解步骤。

致谢

此问题由 Micro Focus 的 Alvaro Muñoz (@pwntester) 发现并负责任地报告。

参考资料

历史记录

2018-10-16:首次发布漏洞报告。

抢先一步

VMware 提供培训和认证,助您加速进步。

了解更多

获取支持

Tanzu Spring 通过一项简单的订阅即可为 OpenJDK™、Spring 和 Apache Tomcat® 提供支持和二进制文件。

了解更多

即将举行的活动

查看 Spring 社区中所有即将举行的活动。

查看全部