大家好,又见面了,我是你们的朋友全栈君。
横向越权:横向越权指的是攻击者尝试访问与他拥有相同(级别或角色)权限的用户的资源。
纵向越权:纵向越权指的是一个低级别(低权限)攻击者尝试访问高级别(高权限)用户的资源。
可通过建立用户和可操作资源的绑定关系,用户对任何资源进行操作时,通过该绑定关系确保该资源是属于该用户所有的。
对请求中的关键参数进行间接映射,避免使用原始关键参数名,比如使用索引1代替id值123等。
防止水平越权的关键是避免用户修改自身的身份标识为其它用户的身份标识。
建议使用基于角色访问控制机制来防止纵向越权攻击,即预先定义不同的权限角色,为每个角色分配不同的权限,每个用户都属于特定的角色,即拥有固定的权限,当用户执行某个动作或产生某种行为时,通过用户所在的角色判定该动作或者行为是否允许。
防止垂直越权的关键是禁止用户自己修改自身的角色或增加自身的权限。
权限提现在四个层面,分别是增加、删除、修改和查询。
增加数据需要的权限控制主要体现在跨权限的增加数据的控制。
增加业务数据具有变动部分,也有不可变部分(比如用户自身的身份标识),主要控制不可变部分。一种思路是该部分由后台进行填充,不依赖于前端传入,或者对前端传入的数据做严格校验。
增加基础数据(比如用户和角色的对应关系,角色和权限的对应关系等)的权限控制,严格判断用户角色和权限,禁止越权添加。
添加请求的身份标识严格校验或者从后端状态中获取,避免前端传入任意身份标识。
对于删除数据,验证校验删除的数据是否在权限范围内。
删除请求的身份标识严格校验或者从后端状态中获取,避免前端传入任意身份标识。
对于修改数据,验证校验修改的数据是否在权限范围内。
修改请求的身份标识严格校验或者从后端状态中获取,避免前端传入任意身份标识。
对于查询数据,一般根据用户标识进行关联查询即可控制在权限范围内。
查询请求的身份标识严格校验或者从后端状态中获取,避免前端传入任意身份标识。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/149890.html原文链接:https://javaforall.cn