横向越权与纵向越权

横向越权与纵向越权


 

 

横向越权

横向越权指的是攻击者尝试访问与他拥有相同权限的用户的资源

 

例子:

用户忘记密码操作!
1、通过手机号,验证码等信息验证身份。
2、跳转修改密码页面
3、输入新密码
4、提交修改密码操作  【调用接口】

接口: ******/newpassword?username=xxx&password=xxx

这样通过修改用户名就可以修改其他用户的密码

 

 

修复方案:

一、可通过建立用户和可操作资源的绑定关系,用户对任何资源进行操作时,通过该绑定关系确保该资源是属于该用户所有的。

二、对请求中的关键参数进行间接映射,避免使用原始关键参数名,比如使用索引1代替id值123等

 


 

 

纵向越权

纵向越权指的是一个低级别攻击者尝试访问高级别用户的资源

 

例子:

其原理是由于Web应用没有做权限控制,或仅仅在菜单上做了权限控制,导致恶意用户只要猜测其他管理页面的URL,就可以访问或控制其他角色拥有的数据或页面,达到权限提升的目的。

 

修复方案:

建议使用基于角色访问控制机制来防止纵向越权攻击,

即预先定义不同的权限角色,为每个角色分配不同的权限,每个用户都属于特定的角色,

即拥有固定的权限,当用户执行某个动作或产生某种行为时,通过用户所在的角色判定该动作或者行为是否允许。

 


 

 

水平权限

攻击者可以根据接口参数中的id加1等操作,来获取其他用户的权限或数据。

 

接口:*******/getUserInfo?userId=12345
攻击者修改userId即可得到他人的信息。

 

 

修复方案:

一、水平权限参数不要用自增值,用id加密、随机数或GUID,但搜索引擎或攻击者可以同样用这个随机数和连接去进行操作

二、web层检查发起请求的用户权限,比如从session信息中获取

三、数据库表增加ownerId字段,增删改查询时加上其作为where语句条件(即每一个信息增加一个发布人的字段,修改的人必须与发布的人为同一个人才可以访问)

 

垂直权限漏洞是指Web应用没有做权限控制,或仅仅在菜单上做了权限控制,导致恶意用户只要猜到了其他页面的URL,就可以访问或控制其他角色拥有的数据或页面,达到权限提升的目的。

修复方案:
只需要对url资源进行权限验证即可。

 

posted @ 2020-07-12 18:17  梦里前进  阅读(613)  评论(0编辑  收藏  举报