其他分享
首页 > 其他分享> > 安全测试之 水平越权访问 与 垂直越权访问 漏洞

安全测试之 水平越权访问 与 垂直越权访问 漏洞

作者:互联网

前言

①越权访问(Broken Access Control,简称BAC)是Web应用程序中一种常见的漏洞,由于其存在范围广、危害大,被OWASP列为Web应用十大安全隐患的第二名。

②该漏洞是指应用在检查授权时存在纰漏,使得攻击者在获得低权限用户账户后,利用一些方式绕过权限检查,访问或者操作其他用户或者更高权限。

③越权漏洞的成因主要是因为开发人员在对数据进行增、删、改、查询时对客户端请求的数据过分相信而遗漏了权限的判定。在实际的代码审计中,这种漏洞往往很难通过工具进行自动化监测,因此在实际应用中危害很大。其与未授权访问有一定差别,目前存在着两种越权操作类型,横向越权操作(水平越权)和纵向越权操作(垂直越权)。

水平越权访问漏洞

水平越权访问是一种“基于数据的访问控制”设计缺陷引起的漏洞。

由于服务器端在接收到请求数据进行操作时没有判断数据的所属人/所属部门而导致的越权数据访问漏洞。 

假设用户A和用户B属于同一角色,拥有相同的权限等级,他们能获取自己的私有数据(数据A和数据B),但如果系统只验证了能访问数据的角色,而没有对数据做细分或者校验,导致用户A能访问到用户B的数据(数据B),那么用户A访问数据B的这种行为就叫做水平越权访问。 

垂直越权访问漏洞

垂直越权是一种“基于URL的访问控制”设计缺陷引起的漏洞,又叫做权限提升攻击。

由于后台应用没有做权限控制,或仅仅在菜单、按钮上做了权限控制,导致恶意用户只要猜测其他管理页面的URL或者敏感的参数信息,就可以访问或控制其他角色拥有的数据或页面,达到权限提升的目的。

防范措施

①前后端同时对用户输入信息进行校验,双重验证机制

②调用功能前验证用户是否有权限调用相关功能

③执行关键操作前必须验证用户身份,验证用户是否具备操作数据的权限

④直接对象引用的加密资源ID,防止攻击者枚举ID,敏感数据特殊化处理

⑤永远不要相信来自用户的输入,对于可控参数进行严格的检查与过滤

 

 

参考博客:https://blog.csdn.net/u012068483/article/details/89553797

标签:漏洞,用户,访问,权限,数据,越权
来源: https://www.cnblogs.com/hls-code/p/15818030.html